e 视频 讲解 


* 以 作者 的 成 长 经 历 为 主线 ， 体 验 项 目 开 发 过 程 
* 以 故事 化 的 形式 讲解 项 目 ， 体 会 项 目 开发 心得 
* 以 十 个 不 同 的 项 目 案例 ， 领 悟 职场 的 生存 技巧 
* 以 真实 的 项 目 开发 场景 ， 展 示 团 队 的 合作 规则 
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内 容 简 介 


PHP 语言 是 当今 使 用 最 为 频繁 的 网 络 编程 语言 之 一 , 一 直 在 Web 开发 领域 占据 重要 的 地 位 。 本 书 通过 
10 个 综合 实例 的 实现 过 程 ， 详 细 讲 解 了 PHP 语言 在 实践 项 目 中 的 综合 运用 过 程 。 这 些 项 目 从 作者 的 学 生 
时 代 写 起 ， 到 项 目 经 理 结束 ， 一 直 贯 穿 作者 最 重要 的 开发 时 期 。 第 1 章 讲解 了 一 个 在 线 留 言 短 系统 的 实现 
流程 ， 第 2 章 讲解 了 综合 供求 信息 系统 的 实现 流程 ;第 3 章 讲解 了 电子 相册 管理 的 具体 实现 流程 ; 第 4 章 
讲解 了 许愿 墙 的 实现 流程 ; 第 5 章 讲解 了 图 书馆 管理 系统 的 具体 实现 流程 ;第 6 章 讲 解 了 企业 网 站 的 具体 
实现 流程 ; 第 7 章 讲解 了 一 个 电子 商务 平台 网 的 具体 实现 流程 ; 第 8 章 讲解 了 开心 斗 地 主 游戏 的 实现 流程 ; 
第 9 章 讲解 了 微 博 的 具体 实现 流程 ;第 10 章 讲解 了 OA 在 线 办 公 的 具体 实现 流程 ,在 具体 讲解 每 个 实例 时 ， 
都 遵循 项 目的 进度 来 讲解 ， 包 括 从 接 到 项 目 到 具体 开发 ， 直 到 最 后 的 调试 和 发 布 。 内 容 循序 渐进 ， 并 穿插 
了 学 习 技巧 和 职场 生存 法 则 ， 引 领 读者 全 面 掌握 PHP 语言 。 

本 书 不 但 适用 于 PHP 语言 的 初学 者 ， 而 且 适 合 有 一 定 PHP 语言 基础 的 读者 ， 也 可 以 作为 已 有 一 定 造 
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从 学 习 者 的 困惑 谈 起 


无 论 你 是 在 校 学 生 ， 还 是 在 职 人 员 ， 只 要 你 在 学 习 编程 ， 我 就 将 笼统 地 称 你 们 为 “学 
习 者 ”。 曾 几何 时 ， 程 序 员 一 直 是 高 薪 和 金领 的 代名词 ， 但 是 殊不知 踏 入 职场 后 突然 发 现 
现实 离 自己 的 期 待 太 远 了 。 有 人 抱 忽 ， 有 人 麻木 ， 但 无 论 是 抱怨 还 是 麻木 ， 都 忽略 了 自身 
的 问题 一 一 你 是 否 具 备 获 取 高 薪 的 实力 。 自 我 评判 一 番 ， 得 出 的 结果 可 能 会 失望 ， 不 禁 会 
感叹 原来 自己 的 水 平 不 过 如 此 。 

既然 自身 实力 不 够 ， 难 道 就 安 于 现状 继续 麻木 下 去 吗 ? 我 相信 大 家 都 不 会 ， 还 需要 继 
续 学 习 ， 继 续 提高 自己 的 能 力 。 可 是 这 就 出 现 一 个 问题 : 市 面 书 海中 种 类 繁多 ， 网 络 资源 
也 浩瀚 无 比 ， 但 都 有 一 个 特点 ， 学 习 起 来 很 是 吃力 。 程 序 难 学 ， 既 有 程序 本 身 是 枯燥 代码 
的 集合 体 的 原因 ， 也 有 编程 体系 博 而 繁琐 的 原因 。 所 以 “学 习 者 ”急需 既 有 深度 又 易 懂 的 
学 习 资料 ， 来 解决 他 们 长 久 以 来 的 困惑 。 


为 什么 要 推出 本 丛书 


本 从 书 是 为 了 解决 上 述 “ 学 习 者 ”的 困惑 而 推出 的 。 

假如 你 是 一 名 在 校 学 生 ， 你 知道 如 何 去 完 成 不 同 的 常见 项 目 吗 ? 知道 在 软件 公司 里 是 
如 何 来 完成 一 个 项 目的 吗 ? 

假如 你 是 一 名 即将 步 入 职场 的 学 生 ， 你 知道 怎样 写 简历 才能 引起 重视 吗 ? 知道 在 软件 
公司 的 工作 流程 吗 ? 

假如 你 是 一 名 在 职 的 程序 员 ， 你 知道 这 个 行业 的 方方面面 和 生存 法 则 吗 ? 知道 上 下 级 
以 及 同事 之 间 的 相处 之 道 吗 ? 

假如 你 是 一 名 资深 的 程序 员 ， 你 知道 怎样 才能 升 职 吗 ? 知道 如 何 才能 利用 技术 来 获取 
更 大 的 回报 吗 ? 

假如 你 是 一 名 项 目 经 理 ， 即 使 一 个 项 目的 完成 如 探 圳 取 物 般 轻 松 ， 但 是 相信 阅读 本 从 
书后 你 将 暮 然 发 现 书 中 内 容 和 自己 的 开发 生涯 是 多 么 的 相似 ， 必 将 激荡 起 你 对 过 去 记忆 的 
i. 

本 从 书 将 为 你 解决 上 述 所 有 问题 ， 不 仅仅 是 对 初学 者 即将 步 入 职场 的 提前 演练 ， 而 且 
也 是 对 在 职 人 员 的 职场 点 拨 。 技 术 方面 的 知识 就 不 用 再 多 说 了 ， 书 中 每 一 页 所 包含 的 内 容 
都 是 作者 多 年 来 的 技术 结晶 。 阅 读本 丛书 后 ， 你 不 但 能 学 到 一 门 技术 ， 而 且 能 够 提前 体验 
或 者 亲身 体验 到 程序 员 的 成 长 历程 。 希 望 本 书 能 为 你 解 惑 ， 也 希望 能 鼓励 你 在 这 一 行业 继 
续 奋斗 下 去 ， 前 面 迎接 你 们 的 将 是 骄阳 的 光芒 。 


EN 
从 书 序 @) 


深入 体验 C# 项 目 开 发 
深入 体验 VC++ 项 目 开 发 
深入 体验 C 语言 项 目 开发 
深入 体验 Java Web 项 目 开 发 
深入 体验 Java 项 目 开发 
深入 体验 PHP 项 目 开发 


序 员 的 各 个 阶段 


曾经 在 CSDN 上 看 到 网 友 总 结 的 程序 员 的 10 种 境界 ， 是 从 技术 层面 进行 划分 的 。 在 此 
将 从 成 长 过 程 来 划分 程序 员 的 不 同 阶段 ， 大 体 分 为 以 下 8 个 阶段 。 

(1) 学 生 阶 段 : 此 阶段 不 仅仅 是 在 校 学 生 ， 也 可 能 是 准备 从 其 他 行业 向 开发 行业 转行 的 
人 员 ， 他 们 需要 学 习 编 程 知识 ， 对 每 一 个 知识 点 都 充满 了 新 奇 ， 对 未 来 充满 希望 。 

(2) 应 届 毕 业 生 : 此 阶段 是 人 生 的 一 个 转折 时 期 ， 刚 刚 离开 校园 走向 社会 。 写 简历 、 参 
加 招聘 会 和 面试 ， 即 将 面 对 新 的 同事 ， 熟 悉 新 的 工作 环境 。 

(3) 职场 菜鸟 阶段 : 刚刚 步 入 职场 ， 正 处 在 对 陌生 环境 的 熟悉 过 程 中 ， 如 果 要 用 最 贴切 
的 专业 名 词 来 概括 的 话 ， 就 是 “试用 期 ”阶段 。 

(4) 初级 程序 员 : 对 项 目 开发 的 基本 流程 有 了 自己 的 认识 , 通过 工作 演练 了 自己 的 技术 。 
此 阶段 处 于 和 同事 、 上 下 级 和 客户 交流 的 摸索 阶段 ， 最 担心 不 知 上 述 哪 种 关系 会 对 自己 带 
来 影响 。 

(5) 有 一 定 工作 经 验 的 程序 员 : 开发 经 验 丰 富 ， 技 术 扎 实 ， 对 同事 关系 、 上 下 级 关系 和 
客户 关系 已 经 处 理 得 如 鱼 得 水 , 同时 也 是 事业 发 展 的 瓶颈 阶段 , 对 职业 提升 方法 有 一 点 迷茫 。 

(6) 经 验 丰 富 的 程序 员 : 积累 了 丰富 的 人 肪 关系， 能 够 轻而易举 地 利用 这 些 关 系 获 得 兼 
职 机 会 。 

(7) 资深 程序 员 : 技术 实力 和 人 脉 关系 俱 佳 ， 一 个 项 目 能 如 探 圳 取 物 般 轻 松 完成 ， 但 是 
也 对 自己 的 未 来 充满 思索 ， 想 重新 寻求 待遇 更 好 的 职位 ， 考 虑 过 跳槽 ， 也 考虑 过 创业 。 

(8) 项 目 经 理 : 也 属于 资深 程序 员 之 列 ， 之 所 以 单独 列 出 ， 是 因为 升 职 了 。 通 常 工 作 
几 年 后 的 资深 程序 员 都 会 升 职 为 项 目 经 理 ， 不 但 在 待遇 上 得 到 提高 ， 而 且 也 在 能 力 上 得 到 
了 升华 。 不 再 单纯 做 技术 ， 而 是 以 技术 为 基础 地 去 实施 管理 和 统筹 ， 运 筹 帷 帐 整 个 项 目的 
进展 。 

为 了 表述 得 更 加 直观 ， 通 过 下 图 来 展示 程序 员 的 成 长 历程 。 

下 图 只 是 代表 了 主流 程序 员 的 成 长 历程 。 都 说 “生路 不 同 ， 各 有 各 的 成 就 ”， 也 许 有 
ee 到 最 后 成 功 升 职 ; 也 许 有 的 程序 半路 创业 de 
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(1) 培养 兴趣 。 

无 论 做 什么 事情 ， 只 要 有 了 兴趣 ， 你 就 喜欢 花 时 间 去 研究 它 。 只 要 你 喜欢 享受 那 调试 
成 功 后 的 喜悦 ， 就 说 明 你 已 经 对 编程 产生 了 兴趣 。 调 试 成 功 后 的 喜悦 会 让 你 更 加 喜欢 编程 ， 
更 享受 它 带 给 你 的 成 就 感 。 闲 暇 时 建议 多 去 专业 编程 论坛 逛 一 逛 ， 灌 治水。 那里 不 但 能 帮 
你 解决 问题 ， 而 且 还 能 给 你 带 来 许多 非 技 术 性 的 收获 。 

Q) 脚踏实地 。 

欲 速 则 不 达 ， 学 编程 切忌 有 浮躁 的 心态 。 很 多 初学 者 刚 学 会 了 点 儿 基 本 的 语法 知识 ， 
调试 成 功 了 几 段 代码 ， 就 迫不及待 地 大 声 宣布 “我 精通 XXX 语言 了 。” 但 是 当 遇 到 问题 之 
后 才 发 现 ， 自 己 学 到 的 只 是 九 牛 一 毛 。 俗 话说 “ 书 山 有 路 勤 为 径 ， 学 海 无 涯 苦 作 舟 ” 是 很 
有 道理 的 。 

G) 多 实践 。 

程序 开发 很 强调 动手 能 力 ， 所 以 实践 就 变 得 尤为 重要 。 有 前 辈 高 人 认为 ， 学 习 编程 的 
秘诀 是 : 编程， 编程 ， 再 编程 ， 练 习 ， 练 习 ， 再 练习 。 对 此 笔者 深 表 赞同 。 学 编程 不 仅 要 
多 实践 ， 而 且 要 早 实践 。 在 看 书 的 时 候 ， 不 要 等 到 你 完全 理解 了 才 动 手 ， 而 是 应 该 在 看 书 
的 同时 敲 代码 ， 程 序 运行 的 各 种 情况 可 以 让 你 更 快 、 更 牢固 地 掌握 知识 点 。 


本 丛书 的 读者 对 象 
初学 编程 的 自学 者 编程 爱好 者 
大 、 中 专 院 校 的 老师 和 学 生 。 相关 培训 机 构 的 老师 和 学 员 
毕业 设计 的 学 生 初 、 中 级 程序 开发 人 员 
程序 测试 及 维护 人 员 参加 实习 的 初级 程序 员 
在 职 程序 员 
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PHP 语 言 的 重要 性 


PHP 语言 是 目前 国内 外 使 用 最 为 广泛 的 程序 设计 语言 之 一 。 它 具有 功能 丰富 、 表 达能 
力 强 、 使 用 方便 灵活 、 执 行 效率 高 、 可 移植 性 好 等 优点 ， 几 乎 可 用 于 所 有 领域 。PHP 语言 
具有 高 级 语言 的 特点 ， 和 C 语言 特点 十 分 相似 ， 具 有 十 分 强大 的 网 络 编程 能 力 ，PHP 语言 
被 广泛 应 用 于 开发 网 站 或 者 轻 量 级 的 Web 程序 开发 。 

使 用 PHP 语言 进行 站 点 设计 和 Web 程序 开发 , 可 以 使 读者 熟悉 当代 网 络 编程 流行 的 重 
要 性 ， 对 于 深入 学 习 计算 机 技术 是 大 有 神 益 的 。PHP 语言 是 计算 机 科学 与 技术 专业 的 基础 
课程 ， 学 习 该 语言 可 为 以 后 选择 Visual C++ 或 Java 软件 开发 竟 定 基础 。 因 此 ， 只 有 熟练 地 
掌握 了 PHP 语言 ， 以 后 才能 更 加 深入 地 掌握 计算 机 技术 。 


本 书 的 特色 


(1) 以 作者 的 成 长 经 历 为 主线 ， 以 项 目 为 单位 ， 每 一 个 项 目 是 一 个 故事 。 

作者 精心 选取 了 经 典 项 目 案例 ， 这 些 案例 的 成 功 造就 了 作者 程序 员 生 涯 的 成 长 之 路 。 
同时 ， 本 书 也 讲述 了 作者 程序 员 生 涯 的 发 展 进程 ， 见 证 了 作者 从 一 个 毕业 生 到 资深 项 目 经 
理 的 成 长 历程 。 为 了 加 深 读 者 对 技术 的 深入 理解 ， 书 中 将 以 故事 化 的 形式 展示 每 个 项 目 ， 
每 个 项 目 案例 都 是 一 个 单独 的 故事 ， 里 面 诠释 了 笔者 对 程序 员 的 人 生体 会 和 感悟。 

Q) 每 个 实例 都 是 精心 挑选 的 典型 代表 。 

书 中 的 实例 都 是 最 典型 的 ， 涵 盖 了 最 主要 、 最 常见 的 应 用 领域 ， 并 包含 了 各 种 类 型 的 
企业 。 每 个 实例 代表 了 作者 职业 生涯 的 一 定时 期 ， 都 极 具 代表 性 。 本 书 在 讲解 实例 过 程 中 ， 
展示 了 各 个 层次 的 技术 实现 技巧 ， 为 读者 日 后 的 亲身 实践 ， 起 到 了 指 路 明灯 的 作用 。 

(3) 揭示 学 习 和 职场 经 验 。 

书 中 涉及 了 一 些 职场 中 的 规则 ， 作 者 根据 自己 许多 年 的 经 历 和 体会 ， 逐 一 在 管理 进度 、 
同事 关系 、 团 队 协作 和 开发 技巧 等 方面 给 读者 以 启示 。 

(4) 结合 图 表 ， 通 俗 易 懂 。 

本 书 在 写作 过 程 中 ， 给 出 了 相应 的 例子 和 表格 进行 说 明 ， 以 使 读者 领会 其 含义 ;对 于 
复杂 的 程序 ， 均 结合 程序 流程 图 进行 讲解 ， 以 方便 读者 理解 程序 的 执行 过 程 ;在 语言 的 叙 
述 上 ， 普 遍 采用 了 短 句 及 易于 理解 的 语言 ， 避 免 了 复杂 句子 和 星 涩 难 懂 的 语言 。 

(5) 给 读者 以 最 大 实惠 。 

本 书 在 配套 光盘 中 不 但 有 书 中 实例 的 源 代 码 ， 并 且 为 书 中 的 项 目 案例 都 配备 了 详细 的 
视频 讲解 。 另 外 ， 还 免费 赠送 给 读者 10 个 典型 的 应 用 案例 ， 供 读者 学 习 使 用 。 


本 书 的 内 容 
全 书 共 分 10 章 ， 具 体内 容 如 下 图 ， 通 过 这 10 章 的 内 容 见证 了 作者 的 成 长 历程 。 


VI 


第 1 章 介绍 使 用 PHP 语言 开发 一 个 简单 在 线 留言 簿 系统 的 
方法 ， 并 详细 介绍 其 具体 的 实现 流程 


第 2 章 介绍 使 用 PHP 语言 开发 综合 供求 信息 系统 的 方法 ， 
让 读者 体会 PHP 在 文件 操作 领域 中 的 应 用 


[e 
" 第 3 章 介绍 使 用 PHP 语言 开发 网 络 相册 的 管理 方法 ， 并 详 
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n 第 4 章 通过 一 个 具体 实例 的 实现 过 程 ， 来 讲解 实现 一 个 许 
u 愿 墙 开发 的 具体 流程 


p 第 5 章 通过 PHP 语言 开发 一 个 图 书馆 管理 系统 , 用 于 毕业 
us 设计 ， 去 了 解 用 户 的 需求 ， 根 据 需求 开发 一 个 完善 的 系统 


了 作 第 6 章 通过 一 个 具体 实例 的 实现 过 程 ， 讲 解 如 何 利用 PHP 
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历 中 第 7 章 讲解 用 PHP 语言 编写 一 个 电子 商务 平台 网 的 具体 实 
的 每 现 过 程 ， 曾 述 系统 的 具体 实现 流程 
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重要 第 8 章 讲解 用 PHP 语言 编写 一 个 简单 的 Web 游戏 的 具体 
项 目 实现 过 程 ， 曾 述 PHP 语言 在 网 络 领域 的 具体 应 用 


第 9 章 用 PHP 语言 实现 一 个 微 博 系统 ,向 读者 讲解 具体 实 
现 过 程 ， 并 剖析 技术 核心 和 实现 技巧 
第 10 章 通过 一 个 在 线 办公 系 统 的 实现 过 程 , 讲解 OA 和 日 
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^ 第 1 章 
贝斯 会 客 间 人 


留言 簿 是 政府 网 站 和 企业 网 站 中 必 不 可 少 的 一 个 模 
块 , 在 现在 的 政府 网 站 上 , 越 来 越 重视 留言 簿 功能 的 开发 。 
在 本 章 中 , 我 们 将 利用 PHP 和 MySQL 技术 开发 一 个 功能 
强大 的 留言 簿 。 

本 章 内 容 将 详细 讲解 留言 簿 系统 的 构建 ， 由 于 讲解 明 
白 透 彻 ， 对 于 刚 学 PHP 程序 的 初学 者 而 言 ， 也 不 是 很 难 ， 
通过 本 章 学 习 ， 读 者 将 牢固 地 掌握 SQL 后 台数 据 库 的 建 
立 、 维 护 以 及 前 台 应 用 程序 的 开发 ， 为 以 后 的 深入 学 习 打 
下 坚实 的 基础 。 


War 一 


身 为 项 目 经 理 的 我 ， 经 常 很 忙 ， 与 客户 交谈 、 写 代码 、 分 析 项 目 ， 还 要 做 报告 。 但 我 
会 利用 每 天 仅 有 的 时 间 ， 听 着 喜欢 的 音乐 ， 对 自己 一 天 的 工作 做 一 个 总 结 。 我 常会 追忆 过 
去 的 奋斗 之 路 ， 追 忆 大 学 四 载 ， 做 过 很 多 东西 : 网 页 设计 、 个 人 网 站 、 照 片 处 理 、 扫 雷 游 
戏 等 。 现 在 回想 起 来 ， 记 忆 最 深刻 的 是 我 做 的 第 一 个 项 目 一 一 贝斯 留言 系统 。 


1.1.1 项 目 来 源 
| 2005 年 5 月 (日 B, #40 


无 论 你 是 菜鸟 ， 还 是 职场 高 手 ， 一 旦 选择 了 一 个 行业 ， 只 要 深入 地 去 挖掘 它 ， 你 就 会 
发 现 ， 你 可 以 在 工作 之 余 挣 点 外 快 。 我 在 大 二 、 大 三 的 时 候 做 过 网 页 设计 、 广 告 设计 ， 当 
然 那 时 候 是 充当 绿叶 ， 并 不 能 真正 做 什么 ， 不 过 现在 是 大 四 的 老 鸟 了， 学 校 里 的 IT 项 目 ， 
还 真 难 逃 出 自己 的 掌心 。 

今天 ， 严 谨 帅 气 的 小 高 又 来 到 了 我 们 究 室 ， 说 学 生 会 主席 贝斯 已 经 成 功 号 召 学 生 会 拨 
动 一 部 分 资金 ， 用 来 制作 一 个 互动 的 留言 短 。 我 们 究 室 IT 人 才 很 多 ， 几 个 作品 都 获得 过 大 
奖 。 贝 斯 知道 小 高 是 我 的 好 朋友 ， 说 什么 也 得 帮 他 这 个 忙 。 有 了 学 生 会 主席 的 大 力 举荐 ， 
加 上 我 们 的 实力 ， 这 个 项 目 就 很 自然 地 被 我 们 拿 下 了 。 


1.1.2. 组建 团队 
2005 年 5 月 2 日 小 两， 团队 


虽然 项 目 不 大 ， 我 们 还 是 组 建 了 一 个 小 团队 ， 团 队 成 员 如 下 。 

舍 友 A: 

一 个 来 自 偏远 山区 的 孩子 ， 家 庭 贫 苦 。 可 能 因为 家 庭 的 原因 ， 酷 爱 学 习 ， 快 成 学 习 超 
人 了 。 仅 有 的 零花 钱 全 都 买 了 辅导 书 : PHP, Java, ASP, Photoshop, Dreamweaver, C+, 
Flash。 最 大 的 优点 是 啥 都 懂 ， 缺 点 是 啥 都 不 精通 。 项 目的 核心 编码 他 是 不 能 胜任 了 ， 但 是 
其 策划 经 验 是 最 好 的 。 

任务 : 负责 项 目 规划 ， 撰 写 系统 设计 规划 书 。 

4X B: 

这 人 外 号 大 叔 ， 因 为 形象 较为 早熟 。 父 母 是 农村 的 ， 他 除了 喜欢 做 数据 库 相 关 的 设计 
和 看 火影 忍者 外 ， 没 有 什么 其 他 爱好 。 

任务 : 负责 需求 分 析 和 数据 库 设 计 。 

$C 

一 个 普通 城市 家 庭 出 身 的 孩子 ， 戴 了 一 副 眼 镜 ， 文 质 彬 彬 。 他 人 十 分 聪明 ， 属 于 一 看 
就 会 的 类 型 ， 所 以 学 习 成 绩 很 好 。 课 余 爱 好 广泛 ， 喜 欢 看 足球 、 踢 足球 。 

任务 : 负责 后 台 设计 。 
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第 1 章 贝斯 会 客 间 


我 : 

性 格外 冷 内 热 ， 喜 欢 要 酷 。 中 学 开始 酷爱 计算 机 ， 大 学 期 间 辛苦 钻研 程序 开发 。 擅 长 
PHP. JSP 等 Web 开发 技术 。 目 前 还 没有 出 人 头 地 ， 等 待机 会 ， 然 后 展 起 高 飞 ， 人 家 称 我 
Bird. 


任务 : 负责 系统 整体 框架 设计 ， 并 协调 项 目 中 各 个 模块 的 进展 。 
具体 职能 结构 如 图 1-1 所 示 。 


TA TAB 


撰写 规划 书 Se 数据 库 设计 


我 
前 台 设 计 
框架 设计 


| 


SAC 
后 台 设计 


1-1 职能 结构 图 


整个 项 目的 具体 操作 流程 是 ， 项 目 规 划一 数据 库 设计 一 框架 设计 一 系统 信息 管理 、 用 
户 管理 、 后 台 设计 。 
(023053558 (205, 4015 

规划 已 顺利 完成 ， 这 也 就 意味 着 前 期 工作 完成 了 。 在 此 我 认识 到 系统 规划 的 重要 性 ， 
系统 规划 是 一 个 项 目的 基础 ， 是 任何 项 目的 第 一 步 工作 。 特 别 是 在 软件 项 目 中 ， 前 期 规划 
分 析 越 发 重要 。 因 为 一 个 项 目 通常 由 一 个 团队 来 完成 ， 良 好 的 规划 分 析 能 更 加 有 针对 性 地 
分 配 任务 。 接 下 来 ， 将 进入 系统 需求 分 析 阶 段 。 


1.2 系统 概述 和 总 体 设计 
[023008355 (3 日 ， 阳 光明 如 


SREK A 做 出 了 项 目 规划 书 ， 整 个 规划 书 分 为 如 下 两 个 部 分 : 
ü 系统 需求 分 析 
O 系统 运行 流程 


1.2.1 系统 需求 分 析 


贝斯 会 客 间 是 一 个 功能 十 分 完善 的 留言 短 ， 留 言 每 有 权限 功能 ， 浏 览 者 可 以 对 主人 说 
悄悄 话 ， 用 户 可 以 轻松 地 回复 留言 ， 其 具体 功能 如 下 。 
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(1) 签 写 留言 。 

签 写 留言 模块 的 主要 功能 包括 : 签 写 留言 模块 、 回 复 留言 模块 。 

(2) 留言 管理 。 

这 个 功能 主要 是 用 户 凭 借 一 定 的 权限 进入 了 系统 后 ， 在 留言 系统 内 对 留言 进行 管理 。 
Q) 展示 留言 。 

展示 留言 模块 的 主要 功能 是 展示 系统 内 的 所 有 留言 信息 。 

(4) 系统 管理 。 

用 户 进 入 系统 后 ， 可 以 对 留言 簿 进行 管理 设置 ， 可 以 根据 需要 自 定义 留言 簿 。 

根据 需求 分 析 总 结 的 用 户 需 求 设计 系统 的 体系 结构 如 图 1-2 所 示 。 


图 1-2 贝斯 留言 往 功能 模块 示意 图 


1.2.2 ”系统 运行 流程 


在 此 模拟 了 系统 的 运行 情景 : 运行 系统 后 ， 进 入 系统 管理 页 ， 用 户 可 以 赁 自己 的 用 
户 名 和 密码 进入 后 台 ， 对 整个 系统 进行 操作 ， 对 留言 进行 管理 ， 以 及 对 系统 进行 设置 ， 如 
图 1-3 所 示 。 


[35558194 Ae. 
在 大 学 里 ， 大 家 都 比较 拖 省 ， 办 事 软 绵绵 的 ， 所 以 一 开始 就 要 死 盯 着 他 们 的 进程 ， 当 
然 对 一 些 有 约会 的 情况 ， 要 稍微 地 纵容 一 下 ， 不 过 经 过 前 期 的 合作 与 磨合 ， 大 家 也 逐渐 有 


了 紧张 感 ， 几 乎 每 一 步 都 是 按照 进度 在 走 。 我 决定 早点 休息 ， 为 接 下 来 的 模块 分 析 阶 段 做 
准备 。 
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KEEN] E c s E 
此 刻 ， 我 心中 只 遗留 着 爱 的 温度 .…… 浏览 留言 。” 签 写 留 言 ” 退出 管理 。 系统 设置 
€ WAME F 2005-05-07 07:59 RRES xes a 


m. MEERE 


TOARE: 2005-05-12 22:31 
嘻 嘻 … 快乐。 


伤 和 照片 好 漂亮， 莱 草 死 你 们 了 一 ~ 


管理 员 回 复 : 2005-05-12 07:50 
谢谢 ~ 有 空 过 来 玩 * 


图 1-3 ”留言 簿 后 台 


13 ”数据库 设 计 


通过 对 系统 的 分 析 ， 建 立 一 个 符合 需求 的 数据 库 是 当前 的 任务 。 今 天 开始 由 含 友 B 设 
计 系 统 数 据 库 ， 听 说 在 数据 库 设 计 的 过 程 中 ， 需 要 建立 需求 的 数据 库 表 与 字段 。 数 据 库 在 
命名 时 需要 规范 字段 名 称 与 表 名 。 然 后 配置 好 数据 库 的 连接 信息 ， 供 用 户 使 用 。 本 项 目 系 
统 的 开发 主要 包括 后 台数 据 库 的 建立 、 维 护 以 及 前 端 应 用 程序 的 开发 几 个 方面 。 数 据 库 设 
计 是 留言 簿 的 一 个 重要 组 成 部 分 。 


1.3.1 系统 运行 流程 
具体 的 数据 库 设 计 ， 售 友 B 参 考 了 舍 友 A 的 需求 分 析 。 由 需求 分 析 的 规划 可 知 整个 项 目 
对 象 有 两 种 信息 ， 所 以 对 应 的 数据 库 也 需要 包含 这 两 种 信息 ， 从 而 系统 需要 包含 两 个 数据 
库 表 ， 分 别 是 : ly gbconfigfilly guestbook. 
(1) ly_gbconfig 表 是 管理 管理 员 账 户 信息 的 ， 如 表 1-1 所 示 。 
R11 管理 员 信 息 


FR 类 型 整理 Ett nu 默认 额外 
id int(10) UNSIGNED i 1 
admin user  varchar(64) gbk chinese ci 5" 
admin pass varchar(64) gbk chinese ci E 


(2) ly_guestbook 表 是 用 来 存储 留言 信息 的 ， 如 表 1-2 所 示 。 


Beslan > 
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表 1-2 留言 信息 表 
FR 类 型 E: E — Null 默认 
id int(10) UNSIGNED Æ 
username varchar(50) gbk_chinese_ci 
content text gbk chinese ci 
reply text gbk chinese ci NULL 
email varchar(128) gbk chinese ci 
userip varchar(22) — gbk chinese ci 
settop tinyint(1) 
ifshow tinyint(1) 
ifaqh inyint(1) 
systime datetime 
replytime datetime 


0 
0 
0000-00-00 00:00:00. 
0000-00-00 00:00:00 
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13.2 数据库 信 息 


当 完 成 了 数据 库 的 设计 后 ， 设 计 者 需要 编写 一 个 数据 库 的 配置 文件 ， 供 程序 员 调 用 ， 


留言 每 的 数据 库 配 置信 息 (config.php) 如 下 : 


«?php 

require once('include/sql class.php');// 调 入 页 面 
$db-new db Mysql(); 

$db-»dbServer = 'localhost';// 服 务 器 地 址 
$db-»dbbase = 'gbook"';// 数 据 库 名 称 
$db-»dbUser = 'root';// 数 据 库 用 户 名 

$db-»dbPwd = '1234';// 数 据 库 密码 
$db->dbconnect () ; 

define('MCBOOKINSTALLED', true);//jE X. 
define('TABLE PREFIX'，"1ly_");// 定 义 数据 库 表 前 级 
if (PHP VERSION > "5.0.0'){// 判 断 PHP 的 版 本 
date default timezone set('PRC'); 

l 


?> 


1.3.3 ”操作 数据 的 常用 方法 


当 编 写 完 配置 信息 后 ， 将 一 些 公 用 的 方法 写 在 一 个 PHP 文件 里 ， 需 要 的 时 候 就 调用 这 


个 文件 ， 在 这 个 留言 人 息 中 ， 也 有 这 么 一 个 文件 ， 其 代码 如 下 (sq]_class.php): 


a< 


<?php 

class db Mysql 

{ 
var $dbServer;// 定 义 数 据 库 服 务 器 
var $dbDatabase; // 定 义 数据 库 
var $dbbase;// 定 义 数据 
var $dbUser;// 定 义 用 户 
var $dbPwd;// 定 义 密码 
var $dbLink; 
var $result;// 执行 query 命令 的 指针 
var $num rows;// 返回 的 条 目 数 
var $insert id;// 传 回 最 后 一 次 使 用 INSERT 指令 的 ID 
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var $affected rows;// 传 回 query 命令 所 影响 的 列 数目 
function dbconnect () 
t 


$this-»dbLink-eémysql connect ($this-»dbServer, $this-»dbUser, $this-»dbPwd); 
if(!$this-»dbLink) $this->dbhalt ("不 能 连接 数据 库 !") ; 
if ($this->dbbase=="") $this->dbbase=$this->dbDatabase; 
if (!@mysql select db ($this->dbbase, $this->dbLink)) 
Sthis->dbhalt ("数据 库 不 可 用 !") ; 
mysql query("SET NAMES 'gbk'"); 
} 
function execute ($sql) // 执 行 方 法 
{ 
$this-»result-mysql query ($sql);// 数 据 库 疑问 
return $this->result; 
} 
function fetch array ($result)// 取 得 数值 
{ 
return mysql fetch array ($result); 
1 
function get rows ($sql)// 获 得 数据 库 行 的 值 
t 
return mysql num rows (mysql query ($sql)); 
5 
function num rows ($result) // 获 得 序列 号 数值 
t 
return mysql num rows ($result); 
) 
function data seek ($result, $rowNumber) // 搜 索 数 据 
t 
return mysql data seek($result,$rowNumber); 
) 
function dbhalt ($errmsg) 
t 
$msg-"database is wrong!";// 数 据 库 错误 信息 
$msg=$errmsg; 
echo"$msg"; 
die(); 
} 
function delete ($sql) {// 删 除数 据 
$result=$this->execute ($sql, $dbbase) ;// 执 行 数据 库 命令 
$this-»affected rows=mysql affected rows (Sthis->dbLink) 7 
Sthis->free result ($result); 
return $this-»affected rows; 
5 
function insert ($sql) {// 插 入 数据 
$result=$this->execute ($sql, $dbbase) ;// 执 行 
$this-»insert id-mysql insert id($this-»dbLink); 
$this-»free result ($result); 
return $this-»insert id; 
H 
function update ($sql) // 更 新 数据 
t 
$result-$this-»execute ($sql, $dbbase); 
$this-»affected rows-mysql affected rows ($this->dbLink); 
$this-»free result ($result); 
return $this-»affected rows; 
H 
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function get num(Sresult) // 获 取 号 码 
$num=@mysql numrows ($result); 
return $num; 
nor free result ($result)// 处 理 为 空 的 数据 
: @mysql free result ($result); 
iom dbclose () // 关 闭 数据 库 
! mysql close ($this->dbLink); 
?7 end class 
?> 


[o0305$581:9, 3& — 

SREK B 顺利 地 完成 了 数据 库 设计 ， 在 制作 数据 库 的 时 候 ， 一 定 要 清楚 每 一 个 表 包 
含 的 信息 ， 因 为 舍 友 B 对 数据 库 表 结构 的 认识 不 清楚 ， 造 成 了 结构 率 乱 ， 在 含 友 A. K 
C 的 大 力 帮助 下 ， 合 友 B 完成 了 数据 库 设计 ， 而 且 把 公用 的 方面 编写 在 了 单独 的 文档 中 
供 后 续 的 开发 者 使 用 。 总 结 完毕 之 后 ， 我 决定 早点 休息 ， 为 接 下 来 的 首页 设计 工作 做 准备 。 


14 前 台 设 计 


上 2005 第 5 月 17 日 ， 小 两， 前 台 要 美丽 


今天 开始 由 我 来 设计 系统 前 台 。 前 台 是 完全 展示 给 浏览 者 的 界面 ， 就 像 人 的 脸 部 一 样 
十 分 重要 ， 除 了 在 结构 上 要 精心 设计 外 ， 还 需要 在 美工 界面 上 下 工夫 ， 以 免 制 作 的 东西 丑 
陋 。 在 前 台 设 计 里 包括 首页 设计 、 首 页 需要 调用 的 页 面 、 留 言 设计 界面 和 验证 功能 的 实现 。 
我 仔细 观察 了 规划 书 和 数据 库 结 构 ， 决 定 寻求 最 大 的 优化 方案 。 


141 首页 设计 


在 首页 里 ， 用 户 可 以 阅读 留言 信息 ， 首 页 是 整个 系统 的 门面 ， 它 的 设计 十 分 重要 ， 如 
图 1-4 所 示 为 本 系统 的 首页 。 
首页 设计 的 代码 (index.php) 十 分 简单 ， 具 体 如 下 : 


«?php 

error reporting(E ALL ^ E WARNING) ;// 错 误 报告 
error reporting(E ALL & -E NOTICE); 
session start(); 

include 'include/config.php'; 

include 'include/para.php'; 

include 'include/page .php';// 启 动 页 面 
$pager = new Page;// 实 例 化 页 面 

$page-$ GET['page']; 

if (empty ($page)) $page-1; 

?> 
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<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"» 

<html xmlns-"http://www.w3.0rg/1999/xhtml"» 

<html> 

<head> 

<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
<title> 浏 览 留言 - <?php echo $gb name?»«/title» 

«script language-"JavaScript" type-"text/javascript" src-"include/checkform. js"> 


«/Script» 

<link href-"css/css.css" rel="stylesheet" type="text/css"> 
</head> 

<body onload="i=0"> 

<?php 


if (!defined ('MCBOOKINSTALLED' ) ) {?><div id="alertmsg"></div><?php exit ();}?> 
<!-- 最 外 层 主 要 区 域 开 始 --> 
«div id-"main"» 

<?php include 'include/head.php';?» 


«div i aste 
«div id-"listmain"» 
«?php 
$sql-"select * from ".TABLE PREFIX."guestbook order by settop desc,id 
desc"; 


$total-$db-»get rows ($sql) ;// 直 接 取出 记录 集 行 数 供 分 页 之 用 
if ($total!=0) // 判 断 记 录 是 否 为 空 


{ 
$pager-»pagedate ($page ,$total,"?page"); 


$rs-$db-»execute($sql." limit $offset,$pagesize"); 
while ($rows-$db-»fetch array($rs)) 
?» ; 
<h2> 
<span class-"leftarea"» 
«img src-"images/icon write.gif" /» «?php echo $rows['username']?» «font 
style-"color:4999;"»] <?php echo date ("Y-m-d H:i",strtotime ($rows["systime"]));?» 
REME: </font> 
<?php if (date ("Y-m-d",strtotime ($rows["systime"]))==date ("Y-m-d")) echo 
"<img src=images/new.gif>';?> 
<?php if ($rows['settop']!-0) echo '«img src-images/settop.gif alt= 已 置顶 >' ; ?> 
«/span» 
«span class-"midarea"» 
<?php if(!empty($ SESSION['admin pass']))( 
if($ifauditing--1)( 
if($rows['ifshow']--0) (?» 
<a href-"admin action.php?ac-setshow&amp; id-«?php echo $rows['id'];?»&page- 
<?php echo $page;?»"» 
«img src-"images/setshow.gif" alt=" 审 核 并 显示 " /»«/a» 
<?php }else{?> 
<a href-"admin action.php?ac-unshow&amp; id-«?php echo $rows['id'];?»&page- 
<?php echo $page;?»"» 
«img src-"images/unshow.gif" alt=" 隐 藏 此 留言 " /»«/a» 
<?php }}?> 
«a href="javascript:if(confirm( "确认 删 除 此 留言 ?7) ) 
location- 
'admin action.php?ac-delete&amp;id- 
<?php echo $rows['id'];?» 
&page-«?php echo $page;?»'"» 
«img src-"images/icon del.gif" alt=" 删 除 此 留言 " /> 
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</a> 
<a href-"edit.php?id-«?php echo $rows['id'];?»&page- 
<?php echo $page;?»"» 
«img src-"images/icon rn.gif" alt=" 编 辑 / 回 复 此 留言 " /></a> 
<?php if($rows['settop']--0) {2> 
«a href-"admin action.php?ac-settop&amp;id-«?php echo $rows['id'];?»&page 
-«?php echo $page;?»"»«img src-"images/settop.gif" alt=" 将 本 留言 置顶 " /> 
«/a» 
<?php Jelse(?» 
«a href-"admin action.php?ac-unsettop&amp;id-«?php echo $rows['id'];?» 
&page- «?php echo $page;?»"» 
«img src-"images/unsettop.gif" alt=" 取 消 置顶 * /»«/a» 
<?php }}?> 
</span> 
<span class="rightarea"> 
<?php if (!empty ($rows['email'])){?> 
<a href="mailto:<?php echo $rows['email']?>"> 
<img src="images/email.gif" alt=" 单 击 用 OutLook 发 送 邮 件 至 : <?php echo 
$rows['email']?»"»«/a» 
<?php )?»«?php if(!empty($ SESSION['admin pass'])) (?» 
«img src-"images/ip.gif" alt=" 留 言 者 IP: <?php echo $rows['userip'];?»"» 
<?php }?> 
</span></h2> 
<div class="content"> 
<?php 
if (empty ($ SESSION['admin pass'])){ 
if ($rows ["ifqqh"]==1) { 

echo '<span class=ftcolor 999> 

(此 留言 为 悄悄 话 ， 只 有 管理 员 才 能 看 哦 ……) </span>'; 
Jelseif ($ifauditing--1)( 
if($rows['ifshow']--0)( 
echo '«span class-ftcolor 999»( 


此 留言 正在 通过 审核 ， 当 前 不 可 见 ……) «/span»'; 
}else{ 
echo $rows['content']; 
} 
)else( 


echo $rows['content']; 
) 
Jelse( 
echo $rows['content']; 
5 
o 
«/div» 
«?php 


if(!empty($rows['reply']1))(?» 

«div class-"reply"»«p» 

<span class-"ftcolor FF9"»«b»«?php echo $replyadmtit;?»: </b> 
<?php echo date("Y-m-d H:i",strtotime ($rows["replytime"]));?» 
«/span»«/p» 

<?php echo $rows['reply'];?» 

«/div» 

<?php 

lr 

// 记 录 集 循环 结束 

$db-»free result ($rs); 

jelse( 
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echo ' 没 有 留言 …*…"'; 

}// 外 层 判 断 记录 集 为 空 结束 

?» 

«/div»«!--listmain 结束 --> 

«/div»«!--list W> 

«div class-"clear"»«/div» 

«div id-"pages" align="center"> 留 言 总 数 : «?php echo $total;?» 条 
<?php $pager-»pageshow();?»«/div» 

«div class-"clear"»«/div» 

«div id-"submit"» 

«form name-"forml" method="post" action-"add.php" onSubmit-"return 
FrontPage Forml Validator (this)"> 

<p><img src-"images/il.gif" /»«img src-"images/add.gif" /»«/p»«br /> 
«label for="user"> 昵 称 : «/label» 

<input type="text" id="username" name="username" value="" />*<br /> 
<label for="email">Email: </label> 

<input type="text" id="email" name="email" value="" /><br /> 


«label for="comment"> 内 容 : «/label» 
<textarea id-content name-"content"»«/textarea»*«br /> 
<label for="comment"> </label> 


<span> 提 交 前 请 按 Ctrl+c 保存 留言 内 容 ， 以 免 程序 出 错 而 丢失 ! 

留言 内 容 不 能 少 于 5 个 字符 ! </span><br /> 

«label for="email"> 悄 悄 话 : «/label» 

«input name="ifqqh" type="checkbox" id="ifqqh" value="1"> 
<span> 当 选中 时 ， 此 留言 只 有 管理 员 可 见 </span><br /> 

<label for="umum"> 验 证 码 : «/1abel» 

<input name-"unum" type="text" id-"unum" size-"10"»* 
«img src-"include/randnum.php?id--1" title=" 单 击 刷新 " 
style-"cursor:pointer" 
onclick-eval('this.src-"include/randnum.php?id-'ci-4'"')»«br /> 
«input type-"submit" id-"sbutton" value=" 确 jE" /><br /> 
«input name-"ac" type="hidden" id-"ac" value-"add"» 


«/form» 
«/div» 
<!-- 最 外 层 主要 区 域 结束 --> 
«/div» 
«?php include 'include/foot.php';?» 
</body> 
«/html» 
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14.2 ”首页 里 调 进来 的 几 个 页 面 

在 首页 里 的 代码 展示 中 ， 可 以 看 到 它 还 调用 了 几 个 外 面 的 代码 ， 这 些 代 码 在 这 个 页 面 
中 起 什么 作用 ， 下 面 将 详细 讲解 。 

1. 系统 信息 

在 首页 里 调 入 了 一 个 “pae.php”， 它 用 来 存储 整个 留言 系统 的 信息 ， 其 代码 如 下 : 


«?php 

$gb name = ' 贝 斯 留言 系统 2.0';// 标 题 

$gb logo -'images/logo.gif'; //Logo 标志 
$index url = '/'; 

$page  - '10';// 页 面 显示 记录 


$timejg = '120'; 

$replyadmtit = ' 管 理 员 回复 ';// 显 示 管理 员 名 称 
$ifauditing = '0'; 

?> 


2. 分 页 信息 


随 着 留言 的 增多 ， 在 一 个 页 面 中 ， 不 可 能 显示 许 许多 多 的 留言 信息 ， 这 样 既 影响 界面 
的 美观 ， 也 不 方便 管理 ， 这 里 可 以 通过 page php 页 面 代码 进行 管理 ， 其 代码 如 下 : 


«?php 
class Page{ 
// 变 量 
var $pagesize;// 页 面 尺 寸 
Var $numrows; 
var $pages;// 页 面 
Var $page; 
var $offset;// 位 移 
var $url; 
function pagedate ($strl,$str2,$str3) {创建 页 面 数据 
global $pagesize, $offset; 
$this-»pagesize = $strl; 
$this-»numrows = $str2; 
$this-»url = $str3; 
$this-»pages = intval($this-»numrows/$this-»pagesize); 
if(Sthis-»numrows$$this-»pagesize)( 
$this-»pages ++; 


} 
// 返 回 错误 的 参数 
$nPage = $ GET['page']; 
if($nPage !- null && !preg match ("/^WXd*$/",$nPage))( 
echo (" 错 误 的 参数 类 型 ! v); 


return false; 


H 
// 判 断 参 数 
if (isset ($nPage) ) { 
$this->page = intval ($nPage); 
} 
else( 
$this-»page - 1; 


c] . 


第 1 章 贝斯 会 客 间 


4 


l 
if($nPage < 1 || $nPage > S$this-»pages)( 
$this-»page - 1; 
} 
$this-»offset = $this->pagesize * ($this->page - 1); 
$pagesize = $this-»pagesize; 
$offset = $this-»offset; 
} 
function pageshow () {// 分 页 功能 
echo "第 [" . Sthis->page . "/" . $this-»pages . "] 页 "; 
if(Sthis-»page > 4)( 
echo "<a href-'" . $this-»url . "=1'> 
«font style-'font-family:Webdings; '?7«/font»«/a»"; 
} 
if(Sthis-»page != 
$pageup = $thi 
echo "«a href- . $pageup . "'> 
«font style-'font-family:Webdings; '»3«/font»«/a»"; 
} 
if ($this->page <= 3){ 
for($i = 1 ; $i <= 10 ; $i ++){ 
if ($i <= $this->pages){ 
if ($i == $this->page){ 
echo "<span>" .Si."</span>";// 宽 度 范围 


) 
else( 

echo "«ahref-'" .$this-»url. "=" . $i . "'»" . $i . "</a>"; 
) 


b 
h 
else if($this-»page >= $this-»pages-6)( 
for($i = $this-»pages-9 ; $i <= $this-»pages ; $i ++){ 
if($i == $this-»page)t 
echo "«span»".$i."«/span»"; 
} 
else( 
echo "<a hrof=""  Stnis-»urb- n-n" SS /a 
} 
} 
H 
else( 
for($i = $this-»page-3 ; $i <= $this-»page46 ; $i ++){ 
if($i == $this-»page)t 
echo "«span»".$i."«/span»"; 
) 
else( 
echo "camref-*'" s$tnis-»urje nm $i SN Si "</a>"; 
} 
} 
} 
if(Sthis-»page != $this->pages && $this-»pages != O)( 
$pagedown = $this-»page + 1; 
echo "<a href-'" . Sthis-»url . "=" . $pagedown . "'» 
«font style-'font-family:Webdings; '»4«/font»«/a»"; 
H 
if(Sthis-»page < $this-»pages-6) 
t 
echo "<a href-'" . $this-»url . "-" , $this-»pages . "'» 


——————————————————— MM M » 


V 深入 体验 PHP 项 目 开发 


«font style-'font-family:Webdings; '»8«/font»«/a»"; 
$ 
} 


?> 
3. 头 部 信息 
在 这 个 系统 中 ， 所 有 的 头 部 信息 都 是 一 样 的 ， 如 图 1-5 所 示 。 
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图 1-5 头 部 设计 
头 部 设计 是 一 个 系统 的 重要 组 成 部 分 ， 其 代码 如 下 : 


<div id="top"> 

«1--l1ogo--» 

«div id-"logoarea"»«a href-"index.php"»«img src=" 

<?php echo $gb logo?»" alt-"«?php echo $gb name?» - fiiiifi"»«/a»«/div» 


<!-- 菜 单 --> 
<div id="menu"> 
<ul> 


<li><a href-"index.php"»«img src="images/i2.gif"><br> 浏 览 留 言 </a></1i> 
<li><a href-"add.php"»«img src="images/il.gif"><br> 签 写 留言 </a></1i> 
<?php if(empty($ SESSION['admin pass'])) 

(?» 

<li><a href-"admin login.php"»«img src-"images/i3.gif"» 

<br> 管 理 留 言 </a></1i><?php jelse(?»«li»«a href-"javascript:if (confirm( 
"您 确认 要 退出 吗 ?') ) location-'admin action.php?ac-logout'"» 

«img src="images/i3.gif"><br> 退 出 管理 </a></1i><?php )?» 

<?php if(!empty($ SESSION['admin pass']))(?» 

<li><a href-"admin set.php"»«img src-"images/admin set.gif"» 

<br> 系 统 设置 </a></1i><?php )?» 

<li><a href-"«?php echo $index url?>"></a> 

</li> 

</ul> 

</div> 

</div> 
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留言 设计 页 面 是 前 台 设 计 的 重要 核心 之 一 ， 它 是 浏览 者 和 系统 沟通 的 桥梁 ， 当 浏览 者 
进入 系统 后 ， 就 可 以 在 此 留言 ， 如 图 1-6 所 示 。 
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其 实现 代码 (add.php) 如 下 : 


<?php 
error reporting(E ALL ^ 已 WARNING) ; // 错 误 报告 
error reporting(E ALL & -E NOTICE); 
session start(); 
include 'include/config.php';// 调 入 页 面 
include 'include/para.php';// 调 入 页 面 
?> 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtml1/DTD/xhtmll-transitional.dtd"» 
<html xmlns-"http://www.w3.0rg/1999/xhtml"» 
«html» 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
<title> 签 写 留言 - <?php echo $gb_name?></title> 
«script language-"JavaScript" type-"text/javascript" 
src-"include/checkform.js"»«/Script» 
«link href-"css/css.css" rel="stylesheet" type="text/css"> 
</head> 
<body onload="i=0"> 
<div id="main"> 
<?php include 'include/head.php';?> 
<div id="submit"> 
<?php if(session is registered('timer') && time() - $ SESSION['timer'] 
«$timejg) (?» 
«div id-"alertmsg"» 
对 不 起 ， 您 不 是 刚 留 言 过 吗 ? 请 <?php echo $timejg;?> 秒 后 再 留言 …… 您 还 需 等 待 : 
<?php echo abs ($timejg- (time()-$ SESSION['timer'])) ?> 秒 <br> 
«a href="javascript:history.back();"> 如 果 没 有 自动 返回 ， 请 单 击 此 处 手动 返回 </a> 
</div> 
«?php 
echo "<meta http-equiv-VW'refreshW" content-V"3; url-index.phpV"»"; 
Jelse( 
if(empty($ POST['ac']))t 


aom 

«form name-"forml" method="post" action-"«?php $ SERVER['PHP SELE']?»" 
onSubmit-"return FrontPage Forml Validator (this)"» 

<p><img src-"images/il.gif" /»«img src-"images/add.gif" /»«/p»«br /> 
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<label for="user"> 了 昵称 : </label> 
«input type="text" id-username name-"username" value-"" /»*«br /> 
<label for-"email"»5Email: «/label» 
<input type="text" id-email name-"email" value-"" /»«br /> 
«label for-"comment"»[j Zi: «/label» 
«textarea id-content name-"content"»«/textarea»*«br /> 
<label for-"comment"» </label> 
<span> 提 交 之 前 请 先 按 Ctrl+C 键 保存 您 的 留言 内 容 ， 以 免 程序 出 错 而 丢失 ! 
留言 内 容 最 少 5 个 字符 ! </span><br /> 
<label for="email"> 悄 悄 话 : «/label» 
«input name="ifqqh" type="checkbox" id="ifqqh" value="1"> 
<span> 当 选中 时 ， 此 留言 只 有 管理 员 可 见 </span><br /> 
<label for="umum"> 验 证 码 : «/label» 
«input name-"unum" type="text" id-"unum" size-"10"»* 
«img src-"include/randnum.php?id--1" title=" 单 击 刷新 " 
style-"cursor:pointer" 
onclick-eval('this.src-"include/randnum.php?id-'cic44'"')»«br /> 
«input type="submit" id-"sbutton" value=" 确 jE" /»«br /> 
<input name-"ac" type="hidden" id-"ac" value-"add"» 
«/form» 
<?php }else{?> 
«div id-"alertmsg"» 
«?php 
if($ PoST['unum']--$ SESSION["randValid"])( 
$username-addslashes (htmlspecialchars ($ POST['username']));// 
$email-addslashes (htmlspecialchars($ POST['email'])); 
$content-addslashes (htmlspecialchars($ POST['content'])); 
$userip-$ SERVER["REMOTE ADDR"]; 
$ifqqh=$ POST["ifqgh"]; 
if (empty ($ifqqh)) $ifqqh=0; 
$systime-date ("Y-m-d H:i:s");// 显 示 系 统 时 间 
if(!empty($content) or !empty ($username) ) { 
$ifshow=""; 
// 还 原 空格 和 回 车 
if(!empty ($content) ) { 
$content=str replace(" ","",$content); 
$content-ereg replace ("\n", "<br> ie 
ereg replace(" ","&nbsp;",$content)); 


} 
if ($ifauditing==1) {$ifshow=0; }else{$ifshow=1; } 
// 还 原 结束 
$sql-"insert into  ".TABLE PREFIX."guestbook (username, email, 
content,userip,systime,ifshow,ifqgh)values('".$username."','".$email."', 
'".$content."','".$userip."','".$systime."',".$1fshow.",".$ifqqh.")"; 
//echo $sql; 
if(($db-»insert ($sq1))»0)( 
$ SESSION['timer']-time(); 
echo "恭喜 您 留言 成 功 ， 正 在 返回 请 稍 候 ……<br> 
«a href=index.php> 您 可 以 点 此 手动 返回 </a>"; 
echo "<meta http-equiv=\"refresh\" content=\"3; 
url=index.php\">"; 
}elsef 
echo "留言 失败 ! 信息 中 可 能 含有 敏感 字符 或 不 利于 程序 运行 的 特殊 字符 ……"; 
echo "<meta http-equiv=\"refresh\" content=\"5; 
url-".$ SERVER['PHP SELE'] ."\">"; 
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echo "昵称 和 留言 内 容 不 能 空 ， 请 重 填 ! 正在 返回 ……<br> 
«a href=index.php> 您 可 以 点 此 手动 返回 </a>"; 
echo "<meta http-equiv=\"refresh\" content=\"3; 
url-".$ SERVER["HTTP REFERER"]."N"»"; 
} 
}else{ 
echo "<script language=\"javascript\">alert 
('" 对 不 起 ， 验 证 码 不 正确 ， 请 重新 输入 ……- ') ;history.back()«/script»"; 
i o 
«/div» 
<?php ))?» 
«/div»«/div» 
<?php include 'include/foot.php';?» 
</body> 
</html> 


14.4 ”验证 码 


在 签 写 留言 下 面 有 一 个 验证 码 ， 在 后 台 登 录 的 时 候 也 会 有 一 个 ， 实 际 上 它们 的 原理 相 
同 ， 即 在 字母 和 数字 之 间 产 生 一 个 4 个 字符 的 随机 数 ， 其 实现 代码 如 下 : 


«?php 

session start(); 

// 定 义 参 数 

$width=50;// 宽 度 

$height=22;// 高 度 

$img-imagecreatetruecolor ($width, $height);// 图 片 颜色 

$times=4; 

$arr2=range (0,9);//$arr3=range ("A", "2"); 

$arr=array merge ($arr2); 

$keys=array rand($arr,$times); 

$str-""; 

foreach ($keys as $i) 

$str.-$arr[$i]; 

$ SESSION["randValid"]-$str; 

for($i-0;$i«$times*2;$i-«)( 

$color-imagecolorallocate ($img,rand(0,156),rand(0,156),rand(0,156)); 
// 干 扰 像 素颜 色 

imageline ($img, rand (0, $width) , rand (0, $height) , rand (0, $width), rand (0, $height), 
$color); 

// 设 置 颜色 
$color-imagecolorallocate ($img, rand (0,255) , rand (0,255) , rand (0,255) ); 
// 颜 色 设 置 

imagesetpixel ($img, rand (0, $width) , rand (0, $height) ,$color); } 
$color=imagecolorallocate ($img, 255,255,255); 
imagestring ($img, 5,5,3, $str,$color); 

header ("content-type:image/png"); 

imagepng ($img); 

imagedestroy ($img); 

ER 
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完成 了 前 台 设 计 后 ， 需 要 对 后 台 进 行 设计 ， 后 台 模 块 是 由 舍 友 C 来 负责 的 。 但 是 舍 友 
C 的 工作 却 一 直 没 有 结果 。 今 天 我 给 他 打 了 一 个 电话 , 他 说 他 女友 的 父母 从 老家 来 看 他 ,这 
儿 天 陪 他 们 去 得 峨眉 山 ， 明 天 还 要 去 九寨 沟 ， 所 以 一 直 抽 不 出 身 来 做 项 目 ! 此 时 的 我 意识 
到 了 问题 的 严重 性 。 看 来 舍 友 C 已 经 是 没有 时 间 来 完成 项 目 了 ， 我 只 好 硬 着 头皮 ， 做 出 了 
如 下 两 个 决定 。 

(1) 找 学 生 会 主席 贝斯 出 面 和 学 校 沟 通 ， 再 宽 限 5 天， 我 们 保证 完成 任务 。 

(2) 我 尝试 完成 舍 友 C 的 任务 。 

幸好 学 校 很 宽容 ， 宽 限 了 我 们 5 天 时 间 ， 而 我 只 能 通宵 达旦 …… 


151 管理 后 台 首页 


后 台 首 页 是 给 管理 人 员 的 一 个 登录 窗口 ， 在 这 个 页 面 中 需要 处 理 用户 的 账户 和 密码 ， 
如 果 账 户 正确 将 进入 系统 ， 不 正确 将 对 它 进行 提示 ， 如 图 1-7 所 示 。 


E 和 各 对 ”由 恒信 20 Windom intemet Explorer Tes > 一] 
(Jenom gnato "plolxl 国 iron — 0 E 
RTR  QtUBR REERERDO -B-—$-nn- mis. IO 6- "| 
zi 

" | 

A3 5 d T g 3 | 

ET SE Wi ges SA | | 

B 管理 登录 | 

= 

Es | 

TBATE: | 

DRE . Eu | 

[eT | 

于 a 

@ reme: | PE ES far Aww 一 
图 1-7 登录 首页 
其 实现 代码 如 下 : 


«?php 

error reporting(E ALL ^ E WARNING); ;// 返 回 错误 报告 

error reporting(E ALL & ~E NOTICE); ;// 返 回 错误 报告 

session start(); 

include 'include/config.php';// 调 入 页 面 

include 'include/para.php'; 

WES 

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"» 
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<html xmlns-"http://www.w3.0rg/1999/xhtml"» 

<html> 

<head> 

<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
<title> 管 理 登录 - <?php echo $gb name?»«/title» 

<link href-"css/css.css" rel="stylesheet" type="text/css"> 


<script language=JavaScript> 
function FrontPage Forml Validator (theForm) 
{ 
if (theForm.admin user.value == "" 
{ 
alert (" 请 输入 管理 员 账 号 ! n) ; // 判 断 管理 员 
theForm.admin user.focus(); 
return (false); 
) 
if (theForm.admin pass.value == "")// 判 断 输 入 的 密码 
t 
alert (" 请 输入 管理 员 密码 ! n); 
theForm.admin pass.focus(); 
return (false); 
) 
if (theForm.unum.value == "")// 判 断 验 证 码 
t 
alert (" 请 您 输入 验证 码 ! "); 
theForm.unum.focus(); 
return (false); 
) 
return (true); 
) 
</script> 
</head> 
<body onload-"i-0;document.getElementsByName ('unum') [0] .value=''"> 
«div id-"main"» 
«?php include 'include/head.php';?» 
«div id-"submit"» 


<?php if(empty($ POST['action'])) 

17> 

«form name="form1" method="post" action-"«?php $ SERVER['PHP SELF']?»" 
onsubmit-"return FrontPage Forml Validator (this)"> 

<p><img src-"images/i3.gif" /»«img src-"images/login.gif" /»«/p»«br /> 
«div id-"submit div"» 

«label for-"admin user"> 管 理 员 账号 : «/label» 

<input name="admin user" type="text" id="admin user"><br /> 
«label for-"admin pass"> 管 理 员 密 码 : «/label» 

<input name="admin pass" type="password" id="admin pass"><br /> 
«label for="unum"> 登 录 验 证 码 : </label> 

«input name-"unum" type="text" id-"unum" size-"10"»* 

«img src-"include/randnum.php?id--1" 

title=" 单 击 刷 新 " 

style-"cursor:pointer" 
onclick-eval('this.src-"include/randnum.php?id-'cic4'"')»«br /> 
«input type="submit" id-"sbutton" value=" 确 jE" /> 

«br /» 

<input name-"action" type="hidden" value-"add"» 

«/div» 

</form> 
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<?php }else{?> 
<div id="alertmsg"> 
«?php 
if($ POST['unum']—-$ SESSION["randValid"]) 
t 
$admin user-$ POST['admin user']; 
$admin pass-md5($ POST['admin pass']); 
$rs-$db-»execute 
("select admin user,admin pass from ".TABLE PREFIX."gbconfig where 
admin user-'".$admin user."'"); 
if($db-»num rows ($rs)!-0)( 


// 检 查 密码 


RR A a 
$row=$db->fetch array($rs); 
$db->free result ($rs); 
if($row['admin pass']==$admin pass){ 


$ SESSION['admin pass']=$admin pass;echo "成 功 登 录 ， 


«a href=".$pageUrl."> 如 果 浏 览 器 没有 自动 返回 ， 请 单 击 此 处 返回 </a>"; 
echo "«meta http-equiv=\"refresh\" content=\"2; 
url=index.php\">"; 


}else{ 
echo "<script language=\"javascript\">alert(' 密 码 不 正确 ! '); 
history.go(-1)</script>";// 显 示 密 码 错误 信息 
} 
} 
else 
{ 
echo "<script language=\"javascript\">alert(' 管 理 账号 不 正确 ! '); 
history.go(-1)</script>";// 显 示 管 理 账 号 错误 信息 
} 
} 
else 
{ 
echo "<script language=\"javascript\">alert (' 验 证 码 不 正确 ， 请 重新 输入 …… UMS 
history.go(-1)«/script»"; 
?» ) 
«/div» 


«?php 

} ?> 

«/div» 

«/div» 

<?php include 'include/foot.php';?» 
</body> 

</html> 


1.5.2 ”管理 留言 


留言 短信 息 中 ， 需 要 对 留言 信息 进行 管理 ， 如 重要 的 留言 信息 置 项 、 一 些 反 动 言论 的 


删除 、 留 言 的 回复 等 操作 ， 如 图 1-8 所 示 。 
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图 1-8 管理 留言 
代码 十 分 简单 ， 其 代码 (admin_action.php) 如 下 : 


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http: //www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"» 
«html xmlns-"http://www.w3.0rg/1999/xhtml"» 
«?php 
include 'check.php';// 插 入 页 面 
include 'include/para.php';// 插 入 页 面 
include 'include/config.php';// 插 入 页 面 
$pageUrl-"index.php?page-".$ GET['page']; 
?» 
«html» 
«head» 
«meta http-equiv-"Content-Type" content-"text/html; charset-gb2312"» 
<title> 管 理 留言 </title> 
<link href="css/css.css" rel="stylesheet" type="text/css"> 
</head> 
<body> 
<div id="main"> 
<?php include 'include/head.php';?» 
«div id-"list"» 
«div id-"alertmsg"» 
<?php if(!empty($ GET['ac']))( 
$id-$ GET['id']; 
$ac-$ GET['ac']; 
if($ac--'delete') 


$db-»delete ("delete from ".TABLE PREFIX."guestbook where id-".$id); 


echo "留言 已 删除 ，3 秒 后 返回 ， 请 稍 候 ……"; 
}elseif ($ac--'settop') 


t 
$db-»update ("update ".TABLE PREFIX."guestbook set settop-1 where 
id-".$id); 
echo "留言 已 置顶 ，3 秒 后 返回 ， 请 稍 候 …… ng 
Jelseif ($ac--'unsettop') 
t 
$db-»update ("update ".TABLE PREFIX."guestbook set settop-0 where 
id-".$id); 
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echo "已 取消 置顶 ，3 秒 后 返回 ， 请 稍 候 …… 
}elseif ($ac=='setshow'){ 
$db-»update("update ".TABLE PREFIX."guestbook set ifshow-1 where 
id-".$id); 
echo "留言 已 显示 ，3 秒 后 返回 ， 请 稍 候 ……"; 
}elseif ($ac=='unshow') { 
$db->update ("update ".TABLE PREFIX."guestbook set ifshow=0 where 
id=".$id); 
echo "留言 已 隐藏 ，3 秒 后 返回 ， 请 稍 候 ……"; 
}elseif ($ac--'logout')( 
session unset('admin pass'); 
session destroy(); 
echo "您 已 经 退出 ，3 秒 后 返回 ， 请 稍 候 ……"; 
Jelse( 
echo “无 此 项 操作 …… "7 
) 


echo "<br><a href=".$pageUrl."> 如 果 您 的 浏览 器 没有 自动 返回 ， 请 单 击 此 处 手动 返回 
«/a»"; 
echo "<meta http-equiv-V'refreshNV" content=\"3; url-".$pageUrl." 


)?» 

«/div» 

«/div» 

«/div» 

<?php include 'include/foot.php';?» 
</body> 

</html> 


15.3 回复 /编辑 留言 


留言 敌对 留言 要 进行 管理 ， 不 仅 要 删除 不 利 的 留言 ， 还 需要 对 一 些 留言 进行 回复 ， 只 
有 这 样 ， 才 会 让 更 多 的 留言 者 进行 留言 ， 如 图 1-9 所 示 。 
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其 代码 (edit.php) 如 下 : 


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"» 

<html xmlns-"http://www.w3.0rg/1999/xhtml"» 

«?php 

include 'check.php';// 调 入 页 面 

include 'include/config.php';// 调 入 页 面 

include 'include/para.php';// 调 入 页 面 

if (isset ($ GET["page"]))$page-$ GET["page"];else $page-1; 

$pageUrl-"index.php?page-".$page; 


$rs-$db-»execute ("select * from ".TABLE PREFIX."guestbook where 
id-".$ GET["id"]); 

if($db-»num rows ($rs)!-0) 

t 


$rows-$db-»fetch array($rs); 
$db-»free result($rs); 
» 
«html» 
«head» 
«meta http-equiv-"Content-Type" content-"text/html; charset-gb2312"» 
<title> 回 复 /编辑 留言 - <?php echo $gb name?»«/title» 
<link href-"css/css.css" rel="stylesheet" type="text/css"> 
</head> 
<script language=JavaScript> 
function FrontPage Forml Validator (theForm) 
t 
if (theForm.content.value == "") 
t 
alert (" 您 不 能 将 留言 内 容 编辑 为 空 ! m); 
theForm.content.focus(); 
return (false); 
) 
return (true); 
5 
«/script» 
<body> 
<div id="main"> 
<?php include 'include/head.php';?> 
<div id="submit"> 
<?php if(empty($ POST['ac'])) (?» 


«form name-"forml" method="post" action-"«?php $ SERVER['PHP SELF']?»" 
onSubmit-"return FrontPage Forml Validator (this)"» 

<p><img src-"images/il.gif" /> 

«img src-"images/edit.gif" /> 

</p> 

<br> 

<h2> 

<img src-"images/icon write.gif" /><?php echo $rows['username']?» 
«font style-"color:$999;"» 

<?php echo date("Y-m-d H:i",strtotime($rows["systime"]));?» 发 表 留 言 : 


</font> 
«/h2» 

«textarea name-"content" cols-"70" rows-"9" id-"content"» 
<?php echo ereg replace ("<br> ""\n"*,ereg replace 
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("&nbsp;"," ",$rows['content'])); ?> 
«/textarea» 
<br> 
<span style="margin-left:80px; "> 管理 员 回复 的 内 容 : «/span» 
«br» 
«textarea name-"reply" cols-"50" rows-"6" id-"reply textarea"» 
<?php echo ereg replace ("<br> ","An",ereg replace ("&nbsp;"," 
",$rows['reply'])); ?> 
«/textarea»«br» 


«input type-"submit" style- 
"margin-left:80px;margin-top:lO0px;" value=" 编 辑 /回复 "” /> 
«input name-"ac" type="hidden" id-"ac" value-"reply"» 
<input name="id" type="hidden" id-"id" value=" 
<?php echo $ GET['id'];?>"> 


</form> 

<?php }else{?> 

<div id="alertmsg"> 

<?php 
$id-$ POST['id'];//ID S£ 
$content-addslashes($ POST['content']);// 显 示 内 容 
$reply-addslashes($ POST['reply']);// 回 复 
$systime-date ("Y-m-d H:i:s");// 显 示 系 统 时 间 
// 还 原 空格 和 回 车 
if(!empty ($content) ) 


$content-str replace(" ","",$content);// 替 换 
$content-ereg replace ("\n", "<br> ", $content) ;// 回 复 信息 
) 
if(!empty ($reply)) 


$reply-str replace(" ","",$reply); 
$reply-ereg replace ("\n", "<br> ",$reply); 


) 
// 还 原 结束 

$db->update ("update ".TABLE PREFIX."guestbook set content-'".$content."" 

,reply-'".$reply."',replytime-'".$systime."' where id-".$id); 
echo "编辑 /回复 成 功 ， 请 稍 候 ……<br> 

«a href=".$pageUrl."> 如 果 浏 览 器 没有 自动 返回 ， 请 单 击 此 处 返回 </a>"; 
echo "<meta http-equiv=\"refresh\" content=\"2; 

url=".$pageUrl."\">"; 

ES 

«/div» 

<?php )?» 

«/div»«/div» 

«?php include 'include/foot.php';?» 

</body> 

</html> 
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在 这 个 留言 血 中 ， 管 理 者 可 以 根据 自己 的 喜好 修改 一 些 信息 ， 如 留言 簿 名 称 ， 留 言 簿 
Logo 等 内 容 ， 界 面 效 果 如 图 1-10 所 示 。 
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图 1-10 系统 设置 


实现 它 十 分 简单 ， 下 面 通过 一 段 代码 来 进行 讲解 ， 其 代码 (admin mp.php) 如 下 : 


«?php 
include 'check.php';// 调 入 页 面 
include 'include/config.php';// 调 入 页 面 
include 'include/para.php';// 调 入 页 面 
$rs=$db->execute ("select * from ".TABLE PREFIX."gbconfig where id=1"); 
if($db-»num rows (Srs) !=0) // 判 断 信 息 
$rows=$db->fetch array ($rs);// 打 开 数 组 
$db->free result ($rs);// 返 回 页面 结 果 
} 


$pageUrl=$_SERVER['PHP_SELF'];// 页 面 链接 
?» 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"» 
<html xmlns-"http://www.w3.0rg/1999/xhtml"» 
«html» 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
<title> 修 改 管理 密码 - <?php echo $gb_name?></title> 
<link href="css/css.css" rel="stylesheet" type="text/css"> 
</head> 
«script language-JavaScript» 
function FrontPage Forml Validator (theForm) 
t 
if (theForm.admin pass.value == "") 
t 
alert (" 请 填写 原 密码 ! ") ; 
theForm.admin pass.focus(); 
return (false); 
p 
if (theForm.admin passl.value == "") 
{ 
alert ("新 密码 还 没有 填 呢 ! ! n); 
theForm.admin passl.focus(); 
return (false); 
$ 
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if (theForm.admin passl.value.length«-2) 
t 
alert ("密码 过 于 简单 ! 最 低 3 个 字符 ") ; 
theForm.admin passl.focus(); 
return (false); 
} 
if (theForm.admin pass2.value == "") 
t 
alert (" 确 认 密码 还 没有 填 ! ! 0; 
theForm.admin pass2.focus(); 
return (false); 
) 
if (theForm.admin passl.value !- theForm.admin pass2.value) 
t 
alert ("密码 不 一 致 ! ! 17); 
theForm.admin passl.focus(); 
return (false); 
) 
return (true); 
ji 
</script> 
<body> 
<div id="main"> 
<?php include 'include/head.php';?> 
<div id="submit"> 
<?php if(empty($ POST['ac'])) (?» 
«form name-"forml" method="post" action-"«?php $ SERVER['PHP SELF']?»" 
onsubmit-"return FrontPage Forml Validator(this)"» 
<p><img src-"images/admin set.gif" /»«img src-"images/set.gif" 
/»«/p»«br /> 
«div id-"submit set left"»«ul» 
«li»«a href-"admin mp.php"> 修 改 管理 密码 </a> 
<li><a href-"admin set.php"> 系 统 参数 设置 </a> 
«/ul»«/div» 


«div id-"submit set right"» 
<label for-"admin pass"> 原 始 密码 : «/label» 
«input type-"text" name="admin pass" /»*«br /> 
«label for="password"> 新 密码 : «/label» 
<input type="text" name="password" />*<br /> 
«label for="admin pass2"> 确 认 新 密码 : «/label» 
<input type="text" name="admin pass2" />*<br /> 
<input type="submit" id="sbutton" name="Submit" value=" 确认 修改 "> 


<input name="ac" type="hidden" id="ac" value="modify"> 
</div> 
<div class="clear"></div> 
</form> 


<?php }else{?> 
<div id="alertmsg"> 
«?php 
include 'include/config.php'; 
//echo md5($ POST['admin pass']); 
$rs-$db-»execute ("select admin pass, 
admin user from ".TABLE PREFIX."gbconfig where 
admin pass-'".md5($ POST['admin pass'])."' and id-1"); 
if(S$db-»num rows (Srs) !=0) 1{ 
$db-»update("update ".TABLE PREFIX."gbconfig set 
admin pass-'".md5($ POST["admin passl"])."' where id-1"); 
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echo "修改 成 功 ， 请 稍 候 …… <br> 
«a href=".$pageUrl."> 如 果 浏 览 器 没有 自动 返回 ， 请 单 击 此 处 返回 </a>"; 
echo "<meta http-equiv=\"refresh\" content=\"2; 
url=" .$pageUrl."\">"; 
}else{ 
echo "操作 失败 ! 原始 密码 不 正确 ， 正 在 返回 ……<br> 
«a href=".$pageUrl."> 如 果 浏 览 器 没有 自动 返回 ， 请 单 击 此 处 返回 </a>"; 
echo "<meta http-equiv=\"refresh\" content=\"2; 
url=".$pageUrl."\">"; 
} 
$db->free result ($rs); 
?» 
«/div» 
«?php )?» 
«/div» 
«/div» 
<?php include 'include/foot.php';?» 
</body> 
</html> 


1.5.5 ”修改 密码 
管理 密码 随 着 时 间 的 增长 ， 有 可 能 泄露 ， 密 码 泄露 对 留言 短 而 言 会 存在 许多 不 安全 的 


因素 。 这 就 要 求 管理 员 在 实际 操作 中 ， 要 随时 更 改 密码 ， 让 自己 的 留言 短 更 安全 。 本 系统 
可 以 修改 密码 ， 如 图 1-11 所 示 。 
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1-11 修改 密码 


下 面 通过 一 段 代 码 来 进行 讲解 ， 其 代码 (admin_setphp) 如 下 : 


«?php 

include 'check.php';//i8 A X ifii 

include 'include/config.php';//iB A Xi [lij 

include 'include/para.php';// 调 入 页 面 

$pageUrl-$ SERVER['PHP SELF'];// 页 面 链接 

2> 

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"» 
<html xmlns-"http://www.w3.0rg/1999/xhtml"» 
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<html> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
<title> 设 置 留 言 簿 - <?php echo $gb name?></title> 
<link href="css/css.css" rel="stylesheet" type="text/css"> 
</head> 
<body> 
<div id="main"> 
<?php include 'include/head.php';?» 
«div id-"submit"» 
<?php if(empty($ POST['ac'])) (?» 
«form name-"forml" method="post" action-"«?php $ SERVER['PHP SELF']?»" 
onSubmit-"return FrontPage Forml Validator (this)"> 
<p><img src-"images/admin set.gif" /»«img src-"images/set.gif" /»«/p»«br /> 
«div id-"submit set left"»«ul» 
«li»«a href-"admin mp.php"> 修 改 管理 密码 </a> 
«li»«a href="admin set.php"> 系 统 参数 设置 </a> 
«/ul»«/div» 


<div id-"submit set right"» 
«label for-"gb name"> 留 言 簿 的 名 称 : «/label»«input type="text" name-"gb name" 
value-"«?php echo $gb name;?»" /»* 将 显示 在 IE 标题 栏 <br /> 
<label for="gb_logo"> M m LOGO: </label><input type="text"name="gb_logo" 
value="<?php echo $gb logo;?»" />* 将 显示 在 左上 角 <br /> 
<label for-"index url"> 网 站 首页 地 址 : «/label»«input type="text" name= 
"index url" value="<?php echo $index url;?>" />* 单 击 “ 网 站 首页 ”的 地 址 <br /> 
«label for="email"> 每 页 留言 条 数 : «/label» 
<select name="pageT" id="pageT"> 
<?php 
// 生 成 数组 
$page array-array('5','8','10','15','20', '25!); 
foreach($page array as $pageT)( 
if($page ==$pageT) { 
echo "<option value-".$pageT." selected>".$pageT."</option>\n"; 
}else{ 
echo "<option value=" .$pageT.">".$pageT."</option>\n"; 
} 
} 
?» 
</select>% «br /> 


«label for="comment"> 连 续 留言 间隔 : «/label» 
<select name="timejgT" id="timejgT"> 
<?php // 生 成 数组 
$timejg array-array('20','40','60','120','240','360'); 
foreach ($timejg array as $timejgT){ 
if ($timejg==$timejgT) { 
echo "<option value=". $timejgT." selected>".$timejgT."</option>\n"; 
}else{ 
echo "<option value=" .$timejgT.">".$timejgT."</option>\n"; 
} 
} 
ums 


«/select»fh (同一 IP 连续 留言 的 时 间 间 隔 ， 以 防 滥 发 留言 ) <br /> 


«label for="replyadmtit"> 回 复 时 显示 : «/label» 
«input type-"text"name-"replyadmtit" value-"«?php echo $replyadmtit;?»"» 
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«br /» 
<label for-"gb logo"> 留 言 需 审 开关 : «/label» 
«input name-"ifauditing" type-"checkbox" id-"ifauditing" 
<?php if(Sifauditing--1) echo 'checked';?» 
value="1"> 选 中 此 项 后 ， 新 留言 需要 管理 员 审核 后 才能 显示 <br /> 
«input name-"ac" type-"hidden" id-"ac" value-"gb set"> 
«input type="submit" style-"margin-left:110px; 
" name-"Submit" value-" 提交 设置 "> 
«/div» 
«div class-"clear"»«/div» 
<script language-JavaScript» 
function FrontPage Forml Validator (theForm) 
t 
if (theForm.gb name.value == "") 
t 
alert (" 留 言 德 名 称 不 能 空 ! ") ; 
theForm.gb name.focus(); 
return (false); 
) 
if (theForm.gb logo.value -- "") 
t 
alert ("ME i Loco 不 能 空 ! "); 
theForm.gb logo.focus(); 
return (false); 
) 


if (theForm.index url.value == "") 
t 
alert (" 网 站 首页 地 址 不 能 空 ! ") ; 
theForm.index url.focus(); 
return (false); 
) 
return (true); 
) 
«/script» 
</form> 
<?php }else{?> 


<div id="alertmsg"> 

<?php 

$gb name- $_POST["gb_name"] ;// 姓 名 

$gb logo-$ POST["gb 10go"];//logo 

$index url-$ POST["index url"];// 首 页 地 址 
$pageT- $_POST["pageT"];// 页 面 信息 
$timejgT=$ POST["timejgT"]; 
$replyadmtit-$ POST["replyadmtit"];// 回 复 
$ifauditing=$ POST["ifauditing"]; 


$parafile-"«"."?php 


\$gb name= '$gb name'; 

\$gb logo-'$gb logo'; 

\$index url-'$index url'; 
\$page = '$pageT'; 
\$timejg='$timejgT'; 
\$replyadmtit="'$replyadmtit'; 
NSifauditing-'$ifauditing'; 


Qn, "yn; 
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// 写 入 空 的 文档 

$filenum = fopen ("include/para.php","w"); 

ftruncate ($filenum, 0); 

fwrite ($filenum, $parafile); 

fclose ($filenum); 
echo "设置 已 保存 ， 请 稍 候 ……<br> 

«a href=".$pageUrl."> 如 果 浏 览 器 没有 自动 返回 ， 请 单 击 此 处 返回 </a>"; 
echo "<meta http-equiv=\"refresh\" content=\"2; url=".$pageUrl."\">"; 

?> 

</div> 

<?php )?» 

«/div» 

«/div» 

<?php include 'include/foot.php';?» 

</body> 

</html> 


教训 ， 重 申 监视 的 重要 性 


经 过 几 天 的 忙碌 ， 我 已 经 完成 了 后 台 的 基本 功能 ， 真 是 赶 着 鸭子 上 架 啊 ! 现在 想来 还 
呆 趴 不 已 。 真 后 悔 当初 没 有 对 舍 友 C 进行 严格 监督 ， 也 幸好 学 校方 面 做 出 了 让 步 ， 否 则 带 
来 的 损失 谁 来 负责 啊 ! 日 常生 活 中 舍 友 C 最 高 效 ， 也 注重 办 事 效率 ， 所 以 对 他 很 放心 ， 就 
没 监视 他 的 工作 。 现 在 我 才 发 现 我 太 想当然 了 ， 差 点 耽误 了 项 目的 工期 。 现 在 唯一 的 工作 
就 是 系统 调试 了 ， 这 个 工作 也 由 我 来 完成 。 


1.6 留言 功能 法 则 


完成 了 后 台 设 计 ， 用 户 还 需要 限制 留言 ， 让 留言 者 对 留言 内 容 进 行 一 种 限制 ， 这 样 有 
助 于 对 留言 内 容 的 管理 。 在 留言 时 ， 对 于 浏览 者 也 有 一 定 的 限制 ， 例 如 ， 昵 称 至 少 为 3 个 
字符 ， 邮 件 格式 是 否 准确 、 留 言 内 容 不 能 少 于 5 个 字 等 ， 如 果 用 户 不 能 满足 这 一 要 求 ， 系 
统 将 提醒 浏览 者 ， 如 图 1-12 所 示 。 
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实现 这 个 功能 并 不 是 使 用 PHP 技术 ,而 是 使 用 JavaScipt 技术 完成 的 ， 下 面 通过 一 段 代 
人 码 (checkform.js) 来 进行 讲解 ， 具 体 如 下 : 


function FrontPage Forml Validator (theForm) // 页 面 表单 判断 
{ 
if (theForm.username.value == "")// 昵 称 
t 
alert (" 请 填写 昵称 ! n); 
theForm.username.focus(); 
return (false); 
H 
if (theForm.username.value.length«3) 
t 
alert (" 昵 称 至 少 应 为 3 个 字符 ! n); 
theForm.username.focus(); 
return (false); 
) 
if(theForm.email.value!-"") (//Jilli E-Mail 
var emaill = theForm.email.value; 
var pattern = /^([a-zA-Z0-9 -])46([a-zA-Z0-9 -])- (V. [a-zA-Z0-9 -])+/; 
flag = pattern.test(emaill); 
if(!flag)( 
alert ("邮件 地 址 格式 不 对 ! m) ; 
theForm.email.focus(); 
return false;) 
H 


if (theForm.content.value == ""){// 留 言 是 否 为 空 
alert (" 留 言 内 容 不 能 空 ! ") ; 
theForm.content.focus(); 
return (false); } 

if (theForm.content.value.length«5) { 

// 留 言 内 容 较 少 
alert ("留言 内 容 最 少 5 个 字符 ! ") 7 
theForm.content.focus(); 
return (false); 

) 

if (theForm.unum.value == "")( 
alert (" 请 输入 验证 码 ! "); 
theForm.unum.focus(); 
return (false); } 
return (true); 

} 
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终于 看 到 了 胜利 的 明光， 最 后 的 项 目测 试 工作 由 我 来 完成 。 我 也 和 贝斯 开 了 个 玩笑 ， 
将 他 和 小 高 的 恋爱 内 容 用 来 测试 , 在 此 我 将 工程 命名 为 “beisi”, 小 高 看 了 肯定 会 咬牙 切 齿 ， 
不 过 一 切 都 可 以 编辑 和 修改 。 
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1.7.1. 系统 运行 浏览 


系统 完成 后 ， 我 高 兴 地 通知 了 小 高 和 贝斯 ， 小 高 欣喜 地 在 买 了 许多 零食 来 到 我 们 究 室 ， 
御 劳 我 们 寝室 的 兄弟 ， 同 时 也 在 我 们 究 室 为 他 们 展示 系统 的 功能 。 


1. 留言 功能 


除 首 页 可 以 留言 外 ， 还 有 专门 的 留言 页 面 ， 在 此 同时 也 对 留言 作 了 限制 ， 了 昵称、 恶意 
留言 都 不 会 提交 成 功 ， 只 有 符合 要 求 的 留言 才 会 提交 成 功 ， 签 写 留言 页 面 如 图 1-13 所 示 。 


当 留 言 完成 后 ， 进 行 提交 ， 


提交 后 的 结果 如 图 1-14 所 示 。 


图 1-13 签 写 留言 页 面 
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图 1-14 留言 成 功 
2. 写 句 悄悄 话 
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在 留言 的 时 候 ， 我 只 想 把 这 个 留言 留 给 管理 员 ， 并 不 想 把 这 个 留言 给 大 家 看 到 ， 如 
图 1-15 所 示 ， 写 一 条 悄悄 话 。 当 留言 成 功 后 ， 悄 悄 话 将 展示 给 普通 浏览 者 的 页 面 如 图 1-16 


所 示 。 
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1-15 正在 签 写 悄悄 话 
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图 1-16 普通 浏览 者 查看 悄悄 话 页 面 
当 管理 员 登 录 留 言 敌后 ， 就 可 以 查看 到 悄悄 话 的 全 部 内 容 ， 如 图 1-17 所 示 。 
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1-17 ”管理 员 查 看 悄悄 话 页 面 
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我 们 的 项 目 ， 不 但 功能 强大 ， 而 且 整 个 界面 颜色 也 很 清爽 。 

在 后 期 维护 上 ， 我 们 也 安排 了 分 工 ， 留 下 了 小 高 的 电话 作为 全 天 候 服务 热线 。 而 我 、 
TR B. SA C 则 开始 为 系统 升级 做 准备 ， 并 考虑 系统 优化 等 方面 的 问题 。 


1.7.3 总 结 


这 个 项 目 其 实 不 大 ， 但 是 我 们 在 学 习 的 过 程 中 ， 不 追求 名 利 ， 不 言 目 自 大 ， 踏 踏实 实 
地 走 好 每 一 步 ， 经 过 十 多 天 的 忙碌 ， 到 最 后 我 们 取得 了 成 功 。 总 结 下 来 ， 有 如 下 4 点 经 验 。 


1. 时 间 的 重要 性 


在 这 个 项 目 里 ， 时 间 最 为 迫切 ， 从 项 目 规划 到 最 后 ， 通 常 要 跟 客户 沟通 和 商定 某 些 模 
块 ， 然 后 用 户 回来 检查 ， 检 查 的 结果 对 项 目的 运作 十 分 重要 ， 如 果 没 有 按 要 求 完 成 ， 客 户 
可 能 会 对 我 们 的 能 力 有 所 怀疑 。 


2. 数据 库 的 标准 设计 


在 给 数据 库 命名 时 ， 大 家 都 喜欢 随心 所 欲 ， 根 据 自己 的 爱好 命名 ， 如 果 一 个 人 开发 全 
部 程序 ， 或 许 不 会 影响 进度 ， 但 是 每 个 人 爱好 与 取向 都 不 同 ， 胡 乱 命名 导致 数据 库 名 称 不 
规则 ， 团 队 成 员 在 一 起 合作 共同 开发 项 目 时 ， 就 会 不 知道 数据 库 设计 者 里 面 的 数据 库 表 是 
什么 信息 ， 或 者 数据 库 字段 表达 什么 意思 。 通 过 这 个 项 目的 开发 ， 总 结 出 ;数据库 命 名 一 
定 要 有 统一 的 标准 ， 让 团队 成 员 一 看 就 能 知道 这 个 表 或 者 这 个 字段 是 什么 用 途 。 

3. 美工 不 能 马虎 


一 个 系统 的 功能 重 在 代码 ， 但 是 皮肤 往往 是 第 一 印象 。 现 在 的 人 都 活 在 匆匆 忙 忙 的 世 
界 里 ， 只 有 印象 留 下 了 ， 才 会 停 下 脚步 来 体验 功能 的 强大 。 项 目 最 终 要 给 客户 留 下 这 样 的 
印象 既 实现 了 需要 的 功能 ， 外 观 又 十 分 好 看 。 


4. 团队 协作 很 重要 


大 家 都 知道 ， 在 一 个 团队 中 协作 是 十 分 重要 的 。 我 们 既 要 重视 自己 的 错误 ， 又 要 原谅 
伙伴 的 错误 。 在 团队 协作 中 ， 尤 其 是 刚刚 成 立 的 团队 ， 难 免 会 出 现 这 样 那样 的 错误 ， 大 家 
要 抱 着 为 实现 共同 目标 的 心情 去 做 这 个 项 目 ， 只 有 这 样 ， 项 目 才 会 继续 向 前 走 ， 并 最 终 
完成 。 
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信息 社区 是 一 个 集 公寓 信息 、 招 聘 信息 、 求 职 
中 信息 、 家 教 信息 、 房 屋 信息 、 车 辆 信息 、 出 售 
、 求 购 信 息 和 招商 引资 信息 于 一 体 的 社区 。 它 旨 在 为 
里 周围 的 小 区 服务 ， 提 供 信息 查询 和 发 布 信息 。 
reed 息 发 布 系统 的 构建 ， 数 据 库 设计 、 
免费 提供 信息 的 发 布 模块 设计 、 付 费 供 求 信息 发 布 模块 设 
计 等 内 容 。 通 过 对 本 章 的 学 习 ， 读 者 应 牢固 掌握 SQL 后 
台数 据 库 的 建立 和 维护 、 前 台 应 用 程序 的 开发 ， 以 及 系统 
的 权限 处 理 ， 更 懂得 以 对 数据 库 有 更 深入 的 了 解 。 
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2.1 网 络 随处 可 见 
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今 社会 ， 越 来 越 重 视 网 站 的 建设 ， 大 到 国家 ， 小 到 社区 ， 都 需要 网 络 来 处 理 日 常事 
务 。 我 突然 间 发 现 周围 有 很 多 的 网 站 ， 从 朋友 堆 里 搜 出 一 个 就 很 可 能 是 个 站 长 。 我 所 居住 
的 四 公里 是 一 个 著名 的 商 圈 ， 围 绕 这 个 商 轿 有 多 个 项 目 ， 这 里 来 来 往往 的 人 不 计 其 数 ， 需 
求 信息 和 提供 信息 的 人 很 多 。 班 长 找到 我 做 这 个 项 目的 时 候 ， 说 真 的 我 心里 没 底 ， 转 念 一 
想 ， 应 该 拿 下 这 个 项 目 ， 于 是 这 成 了 我 第 一 个 对 外 承接 的 项 目 一 一 四 公里 信息 网 。 


2.1.1 项 目 来 源 
[3003 人 1 月 (日 ， 隐 ， 和 班长 的 项 目 

一 向 忙 里 忙 外 的 班长 ， 忙 到 我 这 里 了 ， 说 是 我 最 近 几 天 闲 得 慌 ， 给 我 找 了 个 项 目 ， 要 
我 找 几 个 同学 ， 去 把 项 目 拿 下 ， 挣 点 生活 费 ， 我 欣然 答应 了 。 然 后 找 了 儿 个 同学 ， 将 这 个 
事情 商量 了 一 下 ， 最 终 心里 有 了 合适 人 选 ， 决 定 去 找 他 们 谈 谈 。 
2.1.2 组 建 团 队 
[0230083 11 月 2 日， 小 而 组建 的 团队 

经 过 重重 困难 ， 我 们 组 建 了 一 个 小 团队 ， 团 队 成 员 如 下 。 


同学 A: 
学 生 会 骨干 ， 业 余 时 间 自 学 编程 ， 并 且 个 人 建立 了 一 个 网 站 ， 善 于 项 目 规划 和 网 站 


lik 


ley 


传 。 
任务 : 负责 项 目 规划 ， 撰 写 系统 设计 规划 书 。 
同学 B: 
计算 机 专业 的 优秀 学 员 ， 精 通 C 语言 、 PHP、ASP 技术 ， 并 且 熟 悉 SQL Sever. MySQL 
等 数据 库 ， 对 数据 存储 有 特别 的 研究 。 

任务 : 负责 需求 分 析 和 数据 库 设计 。 

同学 C: 

天 生 的 运动 健将 ， 仿 佛 永远 充满 充 力 。 篮 球场 上 、 游 泳池 中 ， 总 能 找到 他 的 身影 ， 精 
通 PHP. JSP 等 Web 开发 技术 ， 对 网 站 运营 和 营销 有 独特 见解 。 

任务 : 负责 前 台 设计 ， 后 台 设 计 ， 免 费 、 收 费 供求 信息 发 布 模块 设计 。 

我 : 

性 格外 冷 内 热 ， 喜 欢 要 酷 。 中 学 开始 酷爱 计算 机 ， 大 学 期 间 辛 苦 钻 研 程序 开发 。 目 前 
还 没有 出 人 头 地 ， 充 其 量 是 IT 界 一 只 待 飞 的 小 小 鸟 ， 人 家 称 我 Bird。 
任务 : 负责 系统 整体 框架 设计 ， 并 协调 项 目 中 各 个 模块 的 进展 。 
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具体 职能 结构 如 图 2-1 所 示 。 


同学 C 
负责 前 台 设 计 ， 后 台 

同学 A 设计 ， 免 费 、 收 费 供 
负责 项 目 规划 ， 求 信息 发 布 模块 设计 


撰写 系统 设计 规 
划 书 


同学 B 
负责 需求 分 析 和 数 
据 库 设计 


E & 
2 负责 系统 整体 框架 设 
X 一 计 、 协调 


图 2-1 职能 结构 图 


整个 项 目的 具体 操作 流程 是 : 项 目 规划 一 数据 库 设 计 一 框架 设计 一 系统 信息 管理 、 用 
户 管理 、 后 台 设计 。 


项 目 规划 已 顺利 完成 ， 在 制作 信息 网 的 时 候 ， 最 为 重要 的 是 信息 分 类 和 权限 。 为 了 保 
证 项 目 顺利 完成 ， 分 工 十 分 重要 ， 尤 其 是 对 这 种 从 未 开发 的 信息 网 ， 要 多 互相 帮助 ， 少 一 
点 责怪 ， 只 有 这 样 ， 才 能 更 好 地 让 项 目 顺利 完成 。 


2.2 系统 概述 和 总 体 设计 


今天 同学 A 做 出 了 项 目 规划 书 ， 从 表面 看 内 容 清 晰 明 了， 文笔 还 是 那么 的 工整 有 力 。 
总 结 整个 系统 的 开发 流程 如 下 。 

口 系统 需求 分 析 

O ”系统 运行 流程 


2.2.1 系统 需求 分 析 
作为 一 个 供求 系统 ， 其 基本 功能 如 下 。 
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1. 前 台 设计 


网 站 前 台 主要 是 网 站 宣传 以 及 形象 的 宣传 ， 它 对 网 站 生存 发 展 起 着 十 分 重要 的 作 
里 面 有 网 站 导航 、 发 布 免费 的 供求 信息 。 
2. 免费 供求 信息 模块 


免费 供求 信息 包括 十 一 个 模块 、 有 公寓 信息 、 招 聘 信息 、 求 职 信息 、 培 训 信息 、 家 教 


信息 、 房 屋 信息 、 车 辆 信息 、 求 购 信息 等 。 
3. 后 台 设 计 


后 台 设 计 要 从 后 台 管 理 人 员 对 功能 的 易 操 作 适 用 性 、 网 站 的 易 维 护 性 考虑 ， 因 此 采用 


了 框架 设计 。 
4. 付费 供求 信息 发 布设 计 


付费 供求 信息 的 发 布 提供 对 象 为 供求 信息 用 户 ， 是 供求 信息 网 站 非常 重要 的 功能 ， 
是 信息 网 的 便利 点 。 


5. 付费 供求 信息 管理 设计 
付费 信息 管理 设计 有 付费 信息 列表 、 付 费 信 息 审 核 和 付费 信息 删除 等 功能 。 


2.222 ”系统 运行 流程 


在 此 模拟 了 系统 的 运行 情景 ， 运 行 系统 后 ， 在 网 站 中 输入 网 址 ， 就 可 以 浏览 到 这 个 网 


站 ， 流 量 到 相关 的 信息 ， 如 图 2-2 所 示 。 
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2-2 ”系统 运行 效果 
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2.3 ”数据库 设计 


946. 数据 库 的 作用 


今天 开始 步 入 数据 库 的 设计 阶段 ， 此 阶段 的 工作 是 由 同学 B 来 负责 的 。 在 他 看 来 ， 本 
项 目 系 统 的 开发 主要 包括 后 台数 据 库 的 建立 、 维 护 以 及 前 端 应 用 程序 的 开发 两 个 方面 。 数 
据 库 设计 是 四 公里 信息 网 系统 设计 开发 的 一 个 重要 组 成 部 分 ， 所 以 他 尽力 做 到 一 丝 不 苟 ， 
经 过 统筹 规划 之 后 ， 做 出 了 一 个 合理 的 数据 库 设计 方案 。 


2.3.1 数据 库 


具体 的 数据 库 设 计 ， 同 学 B 参考 了 同学 A 的 需求 分 析 。 由 需求 分 析 的 规划 可 知 整个 项 
目 对 象 有 5 种 信息 ， 所 以 对 应 的 数据 库 也 需要 包含 这 4 种 信息 ， 从 而 系统 需要 包含 4 个 数 
据 库 表 ， 分 别 是 : 

O b admin: 用 户 信息 表 ; 

O tb advertising: 广告 信息 表 ; 

O db info: 信息 表 ; 

口 tb_leaguerinfo: 供求 信息 表 。 

同学 B 给 出 了 具体 数据 库 表 的 书面 文件 : 

(1) 用 户 信 息 表 tb_admin， 用 来 保存 管理 用 户 的 信息 ， 表 结构 如 表 2-1 所 示 。 

表 2-1 用 户 信 息 表 


字段 整理 E Nul X LL 

性 u 
id int(4) * auto, increment 
name varchar(50) gb2312 chinese ci F 


pwd varchar(50) gb2312_chinese_ci S 
(2) 广告 信息 表 tb_advertising， 用 来 保存 广告 信息 ， 表 结构 如 表 22 所 示 。 
表 2-2 广告 信息 表 


FR 类 型 整理 E nu X 额外 
性 u 
id int(4) * auto increment 
tle varchar(100) gb2312 chinese ci * 
content varchar(500) gb2312 chinese ci *" 
fdate datetime F 
fag imo) *"» 0 


G) 信息 表 tb info， 用 来 保存 一 些 信息 ， 表 结构 如 表 2-3 所 示 。 
(4) 信息 表 tb leaguerinfo， 用 来 保存 供求 信息 ， 表 结构 如 表 2-4 所 示 。 
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表 2-3 基本 信息 表 


FR 类 型 整理 HE Nul X Ba 
性 a 

id inta) L3 auto increment 
type varchar30) — gb2312 chinese ci * 
tite varchar(50) — 9b2312 chinese ci * 
content varchar500) gb2312 chinese ci * 
linkman varchar(20) —gb2312 chinese ci * 
tel varchar30) — gb2312 chinese ci * 
Checkstate int(1) * 
edate datetime z 
R24 供求 信息 表 

FR 整理 E Nul R Ld 
性 u 

i int(4) * auto increment 
type varchar(20) ge2312 cimese à — & 
tite varchar(50) gb2312_chinese_ci * 
content. varchar(500) gb2312 chinese ci * 
linkman varchar(20) gb2312_chinese_ci * 
tel varchar(30) —gb2312 chinese ci * 
sdate date * 
showday date * 
*9 


checkstate int(1) 


2.32 ”数据 库 配置 信息 


当 创建 好 了 数据 库 后 ， 还 需要 编写 一 个 数据 库 信息 表 ， 供 程序 员 编写 调用 ， 下 面 通过 
- 段 代 码 进行 讲解 ， 其 代码 (config.Php) 如 下 : 


«?php 

$conn-mysql connect ("localhost","root","1234") 
// 数 据 库 基本 信息 
or die (" 数 据 库 服务 器 连接 错误 ".mysql error ()); 

mysql select db("db pursey",$conn) or die 
("数据 库 访 问 错误 " mysql error); 


mysql query ("set names gb2312") ;// 数 据 库 选择 的 字符 型 
?» 


EXm05 108.1009. X&. ÉXA6—T45 

同学 B 的 数据 库 方案 ， 我 感觉 十 分 合理 。 我 深 知 数据 库 工作 至 关 重 要 ， 所 以 都 会 将 必 
要 的 数据 库 配置 信息 编写 在 相应 的 PHP 文件 里 ， 这 样 可 以 加 大 开发 的 速度 ， 也 可 以 让 整个 
项 目 结构 更 清晰 ， 利 于 扩展 。 总 结 完毕 之 后 ， 我 决定 早点 休息 ， 为 接 下 来 的 首页 设计 工作 
做 准备 。 


24 首页 设计 


今天 ， 同 学 C 开始 设计 系统 主页 ， 整 个 项 目 也 进入 到 具体 编码 阶段 。 我 认为 在 网 站 的 
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制作 过 程 ， 首 页 设计 至 关 重 要 ， 尤 其 是 大 型 项 目 中 ， 首 页 一 般 是 将 各 个 板块 分 开 进 行 设计 。 
根据 页 面 布局 ， 他 将 首页 的 设计 工作 分 为 信息 首页 、 项 部 信息 展示 、 底 部 信息 展示 、 左 边 
页 面 展示 几 个 部 分 。 


2.4.1 信息 首页 


虽然 首页 是 将 各 个 页 面 聚合 在 一 起 ， 但 是 需要 一 个 页 面 ， 将 所 需求 的 页 面 放 在 一 起 ， 
下 面 通 过 一 段 代码 进行 讲解 ， 其 代码 (index.php) 如 下 : 


<head> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
<link href="css/style.css" rel="stylesheet"> 
<title> 四 公里 社区 网 </title> 
<style type="text/css"> 
Go 
body { background-image: url(Images/bg.gif); 
} 
ee 
</style></head> 
<body><table width="780" border="0" align-"center" cellpadding-"0" 
cellspacing="0"> 
<tr valign="top"> 
<td colspan="2"> 
<?php include ("top.php");?»«/td» 
«/tr»«tr» 
«td width-"217" valign="top" background-"Images/line2.gif"» 
<?php include ("left.php");?»«/td» 
«td width-"586" valign="top" bgcolor-"£FEFEF6"» 
<?php include ("main.php");?»«/td» 
«/tr» 
«tr» 
«td colspan-"2"»«?php include ("bottom.php");?»«/td» 
«/tr» 
«/table»«/body» 
«/html» 


2.44 ”顶部 信息 展示 


在 页 面 中 ， 项 部 信息 是 用 户 进入 系统 的 第 一 印象 ， 无 论 是 设计 ， 还 是 从 功能 上 讲 ， 都 
是 至 关 重 要 的 ， 本 系统 的 首页 顶部 如 图 2-3 所 示 。 


V 深入 体验 PHP 项 目 开发 
下 面 通 过 一 段 代码 进行 讲解 ， 其 代码 (top php) 如 下 : 


«meta http-equiv-"Content-Type" content-"text/html; charset-gb2312"» 
«link href-"css/style.css" rel-"stylesheet"» 
«table width-"780" height-"201" border-"0" align="center" cellpadding-"0" 
cellspacing-"0"»«tr» 
<td height-"38"»«img src-"Images/banner.gif" width-"780" height-"202" 

border-"0" usemap-"£Map"»«/td»«/tr»«/table» 
«map name-"Map"» 

«area shape="rect" coords-"685,8,744,27" href-"mailto:99pursey(pursey**.com"» 
«area shape="rect" coords-"613,9,666,27"onClick-"this.style.behavior- 

'url(£default£homepage) ';this.setHomePage ('http://');"» 

<area shape="rect" coords-"535,8,593,26" 一 -> 
href-"javascript:window.external.AddFavorite ('http:///', 'VUZ HR dEDC IU " ) "> 

«area shape="rect" coords-"448,8,516,26" href-"admin/login.php"» 


<! 一 后 台 登 录 --> 

«area shape="rect" coords-"356,8,424,28" href-"release.php"» 
<! 一 发 布 信息 页 --> 

<area shape-"rect" coords-"680,61,753,82" href="search.php"> 
<! 一 寻 人 / 物 启 示 --> 


«area shape="rect" coords-"579,62,637,82" href="sale.php"><!-- 出 售 信息 页 --> 
«area shape="rect" coords-"483,62,536,83" href="car.php"><!- 车 辆 信息 页 --> 


«area shape="rect" coords="385, 62, 441, 83" href="teaching.php"><! 一 家 教 信息 页 --> 
<area shape="rect" coords-"290,61,344,83" href-"seekjob.php"» 


<! 一 求职 信息 页 --> 
«area shape="rect" coords-"678,38,740,58" href-"recruitbusiness.php"» 
«i-is v u--» 

<area shape="rect" coords-"579,38,635,58" href-"seekbuy.php"» 


<!-- 求 购 信息 页 --> 
«area shape="rect" coords-"482,38,541,58" href="house.php"><! 一 房屋 信息 页 --> 
«area shape-"rect" coords-"381,39,440,60" href="foster.php"> 


<! 一 培训 信息 页 --> 
«area shape="rect" coords-"290,39,345,59" href="invitejob.php"> 
<!- 招 聘 信息 页 --> 
«area shape-"rect" coords-"204,39,263,86" href="index.php"><! 一 首页 --> 
«/map» 
注意 : 在 上 面 的 网 页 中 ， 都 是 顶部 的 链接 ， 涉 及 了 许多 功能 ， 在 后 面 中 将 不 一 一 讲解 。 


2.4.3 ”底部 信息 展示 


底部 信息 页 面 通常 是 用 来 显示 版 权 信息 的 页 面 ， 本 网 站 版 权 信息 十 分 简单 ， 如 图 2-4 
所 示 为 本 系统 底部 信息 。 
ITO b Eq UA X Sie 
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下 面 通过 一 段 代码 进行 讲解 ， 其 代码 如 下 ; 


«table width-"778" border="0" align-"center" cellpadding-"0" 
cellspacing-"0"» «tr» 
«td width-"778" height-"56" align-"center" background- 
"Images/bottom bg.gif" class="style10"> 四 公里 社区 网 版 权 所 有 </td> 
«/tr» 
«/table» 


2.44 左边 页 面 展示 


在 首页 的 左边 ， 有 许多 信息 ， 有 企业 推广 广告 信息 、 有 搜索 功能 与 联系 功能 ， 如 图 2-5 
所 示 为 首页 左边 的 页 面 。 


“美食 广场 欢迎 您 的 光 虱 ? 

“ 心 悦 * 房 地 产 格 在 00 年 5 月 庙 赔 工 ! 
“" 花园 式 酒店 正式 成 立 ? RUZNE 
， 各 扬 彩 务 印刷 次 迎 修 的 加 盟 4 

“ 诚 冲 电子 酚 务 吉林 省 战略 合作 人 伴 
“， 四 公里 社区 供求 信息 在 峻 开通 4 所 
“你 好 ,欢迎 登录 四 公里 供求 信息 网 


暂 无 公寓 信息 资源 9 


VANCL AET 


Lacie AEEWSCT ARI, 交通 便利 。 环 境 好 。 现 入 住人 员工 
Y PARAE. 有 不 良 嗜 闻 者 误 拓 
EL: 联系 人 : 欧阳 女士 联系 电 
条 m: ERAS. 国 TT 0 09:30:30 
民 碌 路 附近 ,交通 便利 ， 内 设 热水器 可 以 做 白 c 
GREF, ENRE. KARE, FURI. EE- 
n XR BRAE 
联系 人 : 好 先生 联系 电话 : 13095250 
加 公里 社 区 网 TANUBI GUITIN 2005-10-20 09:33:53 
联系 地 址 : 重庆 市 南岸 区 四 公里 IBS. 28. 提供 2 人 间 BAA. SMER, E 
联系 电话 : 022 00000000 有 电视 Rik. 价格 合理 ， 亲 策 化 专人 管理 ， 是 理 起 和 
邮政 映 码 : 400000 联系 人 : FAR 。 联系 电话 : 668699v 
TARRASI GUXTA 2005-10-20 02:25:37 
图 2-5 左边 信息 


下 面 通过 一 段 代 码 进行 讲解 ， 其 代码 (eftphp) 如 下 : 


«meta http-equiv-"Content-Type" content-"text/html; charset=gb2312"> 
«link href-"css/style.css" rel-"stylesheet"» 
«script language-"javascript"» 
function chkinput (form) { 
if(form.content.value--"")( 
alert ("请 输入 查询 关键 字 !") ; 
form.content.select(); 
return false; 
} 
} 
function opengg (id){ 
window.open("showgg.php?id-"-id,"","width-679,height-443"); 
} 
</script> 
«table width-"217" height-"593" border-"0" cellpadding="0" cellspacing="0"> 
«tr» 
«td height-"31" background-"Images/line.gif"»&nbsp; &nbsp; 
«img src-"Images/landian.gif" width-"9" height-"9"»&nbsp; &nbsp; 
<strong> 推 荐 企业 广告 信息 </strong></td> 
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«/tr» 
E 
«td valign="top" background-"Images/line2.gif"» 
«table width-"215" border-"0" align="center" cellpadding-"0" 
cellspacing-"0"» 
E 
<td><table width-"210" border="0" align="center" cellpadding-"0" 
cellspacing-"0"» 
«tr» 
«td height-"5" colspan-"2"»«/td» 
«/tr» 


«?php 
include ("conn/conn.php"); 


include ("JS/function.php"); 
$gsql-mysql query("select * from tb advertising where 
flag-1 order by id desc limit 0,10",$conn); 
$ginfo-mysql fetch array ($gsql); 
if($ginfo--false)( 
2> 
«tr» 


«td width-"10" height-"5"»&nbsp;«/td» 
«td height-"20"»«div align="left"> 暂 无 推荐 企业 广告 信息 !</div> 


«/td» 
«/tr» 
«?php 
) 
else( 
dot 
?» 
<tr> 
«td width-"10" height="5"><div align="center"> </div></td> 
<td height="20"><div align="left"> 
«a href="javascript:opengg (<?php echo $ginfo[id];?>);"> 
<?php 
echo msubstr($ginfo[title],0,30); 
if(strlen($ginfo[title])»30)( 


ocho mn 

} 2> 
«/a» «/div»«/td» 

«/tr» 

«?php 

)while($ginfo-mysql fetch array ($gsq1l)); 
2 
</table></td> 
«/tr» 
</table></td> 
«/tr» 


«tr» 
«td height-"31" background-"Images/line.gif"»&nbsp; &nbsp; 
«img src-"Images/landian.gif" width-"9" height-"9"»&nbsp; &nbsp; «strong» 


信息 快速 检索 </strong> 
«/td» 


«/tr» 
«form name-"forml" method="post" action-"findinfo.php"» 


«tr» 
«td height-"103" align="center" background-"Images/query.gif"» 
«table width-"204" border-"0" cellspacing-"0" cellpadding-"0"» 


«tr» 
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«td width-"204" height="35"> 关 键 字 : 
«input name-"content" type="text" id-"content" size="20"></td> 
«/tr» 
«tr» 
«td height-"30"»4K&nbsp; &nbsp; fT: 
«select name-"type"» 
«option value=" 招 聘 信息 ">- 招 聘 信息 -</option> 
«option value=" 求 职 信息 " selected>- 求 职 信息 -</option> 
«option value=" 培 训 信息 ">- 培 训 信息 -</option> 
«option value=" 家 教 信息 ">- 家 教 信息 -</option> 
«option value=" 房 屋 信息 ">- 房 屋 信 息 -</option> 
«option value=" 车 辆 信息 ">- 车 辆 信息 -</option> 
«option value=" 求 购 信息 ">- 求 购 信息 -</option> 
<option value=" 出 售 信息 ">- 出 售 信息 -</option> 
«option value=" 招 商 引资 ">- 招 商 引 资 -</option> 
«option value=" 公 寓 信息 ">- 公 寓 信 息 -</option> 
<option value=" 寻 人 / 物 启示 ">- 寻 人 / 物 启示 -</option> 
</select> 
</td> 
</tr> 
<tr> 
<td height="23" align="center"><input name="search" type="image" 
class="input1" id-"search" src-"Images/btnl.gif" width-"67" height-"23" 
border-"0" onClick-"return chkinput (form) "> 
«/td» 
«/tr» 
</table> 
</td> 
«/tr» 
</form> 
<tr> 
<td height="31" background="Images/line.gif">&nbsp; &nbsp; 
<img src="Images/landian.gif" width="9" height="9">&nbsp; &nbsp; 
<strong> 联 系 我 们 </strong></td> 
«/tr» 
«tr» 
«td align-"center" valign-"top" background-"Images/line2.gif"» 
«table width-"190" border-"0" cellspacing-"0" cellpadding-"0"» 
«tr» 
«td height-"20"»&nbsp;«/td» 
«/tr» 
«tr» 
«td height-"20"»&nbsp;«span class="stylel"> 四 公里 社区 网 </span></td> 
«/tr» 
«tr» 
«td height-"3" background-"Images/tiao.gif"»«/td» 
LEES 
<tr> 
«td height="20"> 联 系 地 址 : 重庆 市 南岸 区 四 公里 </td> 
«/tr» 
«tr» 
«td height="20"> 联 系 电话 : 023-00000000«/td» 
«/tr» 
«tr» 
«td height="20"> 邮 政 编码 : 400000«/td» 
«/tr» 
«/table» 
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</td> 
rq» 
</table> 


2.5 ”免费 发 布 供求 信息 模块 


n, Aigh 


经 过 过 去 3 天 的 忙碌 ， 终 于 将 系统 的 门面 做 好 了 。 接 下 来 还 得 继续 努力 ， 从 今天 开始 ， 
将 实现 免费 发 布 供求 信息 模块 的 编码 工作 。 免 费 供求 信息 的 发 布 是 为 用 户 提供 的 十 分 重要 
的 功能 ， 是 供求 网 站 功能 的 核心 ， 四 公里 信息 发 布 的 网 站 中 ， 总 共有 十 一 种 信息 ， 分 别 是 
公寓 信息 、 招 聘 信息 、 求 职 信息 、 培 训 信息 、 家 教 信息 、 房 屋 信息 、 车 辆 信息 、 求 购 信息 、 
出 售 信息 、 招 商 引 资 、 寻 人 / 物 启示 等 类 型 供求 信息 ， 信 息 发 布 成 功 后 ， 并 不 能 即时 得 到 显 
示 ， 需 要 管理 人 员 进 一 步 核实 。 


2.5.1 免费 供求 信息 的 实现 


用 户 可 以 在 首页 单 击 “ 我 要 发 布 ”， 看 到 如 图 2-6 所 示 的 页 面 ， 程 序 会 先 验证 用 户 是 否 
输入 信息 ， 如 果 验 证 失败 ， 则 输出 一 个 提示 。 
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图 2-6 发 布 免费 信息 
下 面 通过 一 段 代码 进行 讲解 ， 如 何 实现 这 个 功能 ， 其 代码 (release.php) 如 下 : 


<html> 

<head> 

<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
<link href="css/style.css" rel="stylesheet"> 
<title> 四 公里 社区 网 </title> 

<style type="text/css"> 
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过 站 < 二 
body { 
background-image: url(Images/bg.gif); 
} 
-=--> 
</style></head> 
<body> 
<table width="780" border="0" align="center" cellpadding="0" cellspacing="0"> 
<tr valign="top"> 
<td colspan="2"><?php include ("top.php");?»«/td» 
«/tr» 
«tr» 
«td width-"217" valign="top" background-"Images/line2.gif"» 
<?php include ("left.php") ;// 调 入 左边 网 页 
?»«/td» 
«td width-"586" valign="top" bgcolor-"£FEFEF6"» 
«?php include("release content.php");?»«/td» 
«/tr» «tr» 
«td colspan-"2"»«?php include ("bottom.php");?»«/td» 
«/tr» 
</table> 
</body> 
</html> 


2.5.2 ”检查 信息 


当 用 户 在 页 面 中 输入 免费 信息 提交 后 ， 系 统 要 对 信息 进行 判断 是 不 是 符合 要 求 
不 符合 要 求 将 给 出 提示 ， 如 图 2-7 所 示 。 


图 2-7 信息 提示 


下 面 通过 一 段 代 码 进行 讲解 ， 其 代码 (release_contentphp) 如 下 : 


«style type="text/css"> 

e 

.stylel (color: £FF0000)« —HoXi& -— 

=> 

</style> 

<link href-"css/style.css" rel="stylesheet"> 
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«script language-"javascript"» 
function checkform(form) {// 自 定义 一 个 函数 
for (i=0;i<form.length;i++) {// 检 查 表单 是 不 是 为 空 
if(form.elements[i].value--"") {// 如 果 表单 为 空 
alert ("请 将 发 布 信息 填写 完整 !") ; // 弹 出 提示 
form.elements [i] .focus () ;// 将 鼠标 光标 定位 在 表单 为 空 的 位 置 
return false;// 返 回 


} 
} 
</script> 
<table width="563" height="407" border="0" cellpadding="0" cellspacing="0"> 
«tr» 
«td width-"563" height-"407" valign="top" bgcolor-"£FFFFFF"» 
«form name-"forml" method="post" action-"release ok.php" > 
<table width-"563" border-"0" cellspacing-"0" cellpadding-"0"» 
«tr background-"Images/mianfei.gif"^ 
«td height-"27" colspan-"2"»&nbsp;«/td» 
«/tr» 
«tr» 
«td height-"24" colspan-"2"»&nbsp;«/td» 
«/tr» 
«tr» 
«td width-"130" height-"30" align="right"> 信 息 类 别 : «/td» 
<td width="433" height="30"><select name="type"> 
<option value=" 招 聘 信息 ">- 招 聘 信息 -</option> 
«option value=" 求 职 信息 " selected>- 求 职 信息 -</option> 
«option value=" 培 训 信息 ">- 培 训 信息 -</option> 
«option value=" 家 教 信息 ">- 家 教 信息 -</option> 
«option value=" 房 屋 ">- 房 屋 信息 -</option> 
<option value=" 车 辆 ">- 车 辆 信息 -</option> 
«option value=" 求 购 信 息 ">- 求 购 信息 -</option> 
<option value=" 出 售 信息 ">- 出 售 信息 -</option> 
«option value=" 招 商 引资 ">- 招 商 引 资 -</option> 
«option value=" 公 寅 信息 ">- 公 寓 信 息 -</option> 
«option value=" 寻 人 / 物 启示 ">- 寻 人 / 物 启示 -</option> 
«/select» 
&nbsp;«span class="stylel">*&nbsp; 请 正确 选择 您 要 发 布 的 信息 类 别 </span></td> 
«/tr» 
cepe 
«td height-"30" align="right"> 信 息 标题 : «/td» 
«td height-"30"»«input name- 
"title" type="text" id-"title" size-"50"»«/td» 
«/tr» 
«tr» 
«td height-"30" align="right"> 信 息 内 容 : </td> 
«td height="30"> 
<textarea name-"content" cols-"50" rows-"8" 
ide"content"»«/textarea» 
«/td» 
«/tr» 
«tr» 
«td height-"30" align-"right"»lKK&nbsp; &&nbsp; 人: </td> 
«td height-"30"»«input name-"linkman" type="text" id-"linkman"» 


«/td» 
«/tr» 
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«tr» 
«td height-"30" align="right"> 联 系 电话 : «/td» 
«td height-"30"»«input name-"tel" type="text" id-"tel"» 
«/td» 
«/tr» 
«tr align="center"> 
«td height-"80" colspan-"2"» 

«input name-"imageField" type-"image" class-"inputl" 
src-"Images/fa.jpg" width-"145" height-"46" border-"0" onClick-"return 
checkform(form);"» 

«/td» 
«/tr» 
</table> 
</form> 
</td> 
«/tr» 
</table> 


2.5.8 ”处 理 免费 信息 


当 表单 的 数据 库 符 合 要 求 时 ， 提 交 表 单 的 信息 到 数据 处 理 页 进行 处 理 ， 下 面 通 过 一 段 
代码 进行 讲解 ， 处 理 免费 的 数据 信息 代码 (release_ok.php) 如 下 : 


<?php 
include ("conn/conn.php"); 
// 调 入 数据 库 连 接 页 
$type=$ POST[type]; 
// 获 取信 息 类 型 
$title=$ POST[title]; 
// 获 取信 息 标题 
$content-$ POST[content]; 
// 获 取信 息 内 容 
$linkman-$ POST[linkman]; 
// 获 取 联 系 人 
$tel-$ POST[tel]; 
// 获 取 联 系 电话 
$edate=date ("Y-m-d H:i:s"); 
// 获 取 免 费 电话 
$sql-mysql query ("insert into 
// 将 免费 的 信息 添加 到 数据 库 
tb info(type,title,content,linkman,tel,checkstate, edate) 
values('$type','$title','$content', '$linkman', '$tel',0, '$edate') "); 
if($sql) 
{// 添 加 成 功 与 失败 都 会 弹出 提示 
echo "<script>alert (' 恭 喜 您 ， 信 息 发 布 成 功 ! 
');window.location.href-'release.php'; 
</script>"; 
}else{ 
echo "«script»alert (' 对 不 起 ， 信 息 发 布 失败 ! ') ;history.back(); 
«/script»"; 
} 
2> 


当 添 加 完成 数据 后 ， 会 弹出 提示 信息 ， 提 示 用 户 ， 信 息 是 不 是 添加 成 功 ， 如 图 2-8 所 
示 为 弹出 的 提示 信息 。 
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2-8 弹出 的 提示 信息 


[moss (08 ， &. $4609 

今天 同学 C 完成 了 免费 信息 发 布 模块 ， 我 发 现 整个 功能 和 原来 做 过 的 留言 系统 十 分 相 
似 ， 都 是 向 数据 库 里 编写 信息 ， 在 编写 的 过 程 中 有 提示 ， 如 果 符合 要 求 则 提交 到 数据 库 。 
唯一 不 同 的 是 ， 这 里 发 布 的 信息 ， 还 需要 管理 员 审核 ， 只 有 审核 通过 了 ， 才 能 显示 到 页 
面 上 。 


2.6 ”信息 搜索 模块 


今天 同学 C 开始 实现 信息 搜索 模块 的 编码 工作 ， 我 认为 当 信息 发 布 后 ， 搜 索引 擎 就 变 
得 十 分 重要 ， 信 息 检索 是 对 已 存在 于 数据 库 中 的 内 容 进行 搜索 ， 这 是 最 有 效 的 方法 。 当 用 
户 在 众多 的 信息 中 寻找 自己 需要 的 信息 时 ， 就 需要 进行 搜索 ,如 图 2-9 所 示 ， 是 搜索 关键 字 
为 “公寓 ”的 信息 。 
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图 2-9 搜索 的 结果 
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下 面 通过 一 段 代码 进行 讲解 如 何 实 现 搜索 的 过 程 ， 其 代码 (findinfo.php) 如 下 : 


<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
<link href="css/style.css" rel="stylesheet"> 

<style type="text/css"> 

«1— 

.Stylel2 (color: #FFFFCC}// 样 式 

.stylel3 (color: #FF8502} 


--> 

</style> 

<table width="780" border="0" align="center" cellpadding="0" 
cellspacing="0"> 


<tr valign="top"> 
<td colspan="2"> 
<?php include ("top.php");?></td> 
«/tr» 
SETS 
<td width="217" valign="top" background="Images/line2.gif"> 
<?php include ("left.php");?»«/td» 
<td width-"586" valign="top" bgcolor="#FEFEF6"> 
<table width="563" height="587" border="0" cellpadding="0" 
cellspacing="0"> 
<tr> 
<td width="563" height="587" valign="top" bgcolor="#FFFFFF"> 
<table width="563" border="0" cellspacing="0" cellpadding="0"> 
<tr> 
<td width="563" height="27" bgcolor="#3983B6">&nbsp; &nbsp; &nbsp; &nbsp; 
<span class-"stylel2"»«span class-"stylel3"» 
«/span»&nbsp; &nbsp; «strong» Z4 «/strong»«/span»«/td» 
«/tr» 
«tr» 
«td align="center" valign="top"> 
<?php 
include ("conn/conn. php") ;// 连 接 数据 库 
Stype=$_POST [type] ; // 获 取 数据 类 型 
$content-$ POST[content];// 获 取 关 键 字 
$sqll-mysql query ("select * from tb leaguerinfo where checkstate-1 
and type-'$type' and (content like'$$content$' or title like'$$content$' or 
linkman like'$$content$' or tel like'%$content%')");// 检 索 付 费 的 供求 信息 
$infol=mysql fetch array ($sq11); 
$sql=mysql query ("select * from tb info where checkstate-1 
and type-'$type' and (content like'$$content$' or title like'$$content$' or 
linkman like'$$content$' or tel like'%$content%')");// 检 索 免 费 的 供求 信息 
$info-mysql fetch array ($sql); 
?» 
«?php 
if(Sinfol)( 
do( 
2> 
<table width="540" border="0" cellspacing="0" cellpadding="0"> 
<tr> 
<td height="26"> 
<?php echo str_ireplace ($content, 
"<font color-'£FF0000'»".$content."«/font»",$infol[typel);?» &nbsp; 
«-- ! 对 与 查询 有 关 的 关键 字 所 匹配 的 信息 进行 描 红 --> 
<?php echo str ireplace ($content, 
"<font color="#FF0000'>".$content."</font>", $infol[title]);?>&nbsp; &nbsp; 
<--! 对 与 查询 有 关 的 关键 字 所 匹配 的 时 间 进 行 描 红 --> 
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<?php echo str ireplace ($content, 
"<font color-'£FF0000'»".$content."«/font»",$infol[edate]);?»«/td» 
«-- ! 对 与 查询 有 关 的 关键 字 所 匹配 的 信息 内 容 进 行 描 红 --> 
«/tr» 
«tr» 
«td height-"26"»&nbsp; &nbsp; &nbsp; &nbsp; 
<?php echo str ireplace($content," 
«font color-'£FF0000'»".$content."«/font»",$infol[content]);?»«/td» 
«/tr» 
«tr» 
«td height-"26"»&nbsp; KA: 
<?php echo str ireplace($content," 
«font color-'£$FF0000'»".$content."«/font»",$infol[linkman]);?» 
&nbsp; &nbsp; &nbsp;<--! 对 与 查询 有 关 的 关键 字 所 匹配 的 联系 人 进行 描 红 --> 
联系 电话 : <?php echo str ireplace($content," 
«font color-'£$FF0000'»".$content."«/font»",$infol[tel]);?»«/td» 
<--! 对 与 查询 有 关 的 关键 字 所 匹配 的 联系 电话 进行 描 红 --> 
«/tr» 
«tr» 
«td height-"3" background-"Images/linel.gif"»«/td» 
«/tr» 
</table> 
<?php 
}while ($infol=mysql fetch array($sql1)); 
?» 
«/td» 
«/tr» 
«tr» 
«td height-"140" align="center" valign="top"> «br» 
«?php 
if ($info){ 
do{ 


?> 
«table width="540" border-"0" cellspacing-"0" cellpadding="0"> 
«tr» 
«td height-"26"»[«?phpecho str ireplace ($content, "<font 
color-'£FF0000'»".$content."«/font»",$info[type]);?»] &nbsp; 
<?php echo str ireplace($content," 
«font color-'£FF0000'»".$content."«/font»",$info[title]);?» 
&nbsp;&nbsp;«?php echo str ireplace ($content, " 
«font color-'£FF0000'»".$content."«/font»", $info[edate]);?»«/td» 
«/tr» 
«tr» 
«td height-"26"»&nbsp; &nbsp; &nbsp; &nbsp; 
<?php echo str ireplace($content," 
«font color-'£FF0000'»".$content."«/font»",$info[content]);?»«/td» 
«/tr» 
«tr» 
«td height-"26"»&nbsp; KRA: 
<?php echo str ireplace($content," 
«font color-'4FF0000'»".$content."«/font»",$info[linkman]);?» 
&nbsp; &nbsp; &nbsp; 联系 电话 : <?php echo str ireplace($content," 
«font color-'4FF0000'»".$content."«/font»",$info[tel]);?»«/td» 
«/tr» 
«tr» 
«td height-"3" background-"Images/linel.gif"»«/td» 
«/tr» 
«/table» 
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«?php 
} while ($info=mysql fetch array ($sql));// 搜 索 到 了 免费 信息 
} 
}elsef 
?» 
«?php 
if(Sinfo)( 
do( 
?» 
«table width-"540" border-"0" cellspacing-"0" cellpadding-"0"» 
«tr» 
«td height-"26"» [<?php echo str ireplace($content, 
"<font color-'£FF0000'»".$content." 
</font>", $info[type]);?>] &nbsp; 
<?php echo str ireplace ($content," 
«font color='#FF0000'>".$content. "«/font»",$info[title]);?»&nbsp; &nbsp; 
<?php echo str ireplace ($content," 
«font color='#FF0000'>".$content. "«/font»",$info[edate]);?»«/td» 
«/tr» 
«tr» 
«td height-"26"»&nbsp; &nbsp; &nbsp; &nbsp; 
<?php echo str ireplace($content," 
«font color-'£FF0000'»".$content."«/font»",$info[content]);?»«/td» 
«/tr» 
«tr» 
«td height-"26"»&nbsp; IKRA: 
<?php echo str ireplace($content," 
«font color-'4FF0000'»".$content."«/font»",$info[linkman]);?» 
&nbsp; &nbsp; &nbsp; 联系 电话 : <?php echo str ireplace($content," 
«font color-'4FF0000'»".$content."«/font»",$info[tel]);?»«/td» 
«/tr» 
«tr» 
«td height-"3" background-"Images/linel.gif"»«/td» 
«/tr» 
«/table» 
«?php 
} while ($info=mysql fetch array ($sql)); 
}else{ 
E 
«table width-"540" border-"0" cellspacing-"0" cellpadding-"0"» 
«tr» 
«td align="center"> 您 检索 的 信息 资源 不 存在 ! </td 
«/tr» 
«/table» 
«?php 
H ) 
?» 
«/td»«/tr» 
«/table» 
<p>&nbsp;</p> 
<p>&nbsp;</p></td> 
</tr> </table> </td> 
«/tr»«tr» 
«td colspan-"2"»«?php include ("bottom.php");?»«/td» 
«/tr» 
«/table» 
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从 今天 开始 ， 整 个 项 目 进入 后 台 编 码 阶 段 。 其 实 对 于 一 个 站 点 来 说 ， 不 管 前 台 的 功能 
有 多 丰富 、 有 多 绚丽 ， 都 离 不 开 后 台 的 管理 。 根 据 项 目 规划 书 ， 在 本 项 目的 后 台 功 能 中 ， 
需要 有 发 布 需求 信息 的 管理 、 免 费 浏 览 信息 的 管理 、 企 业 广 告 信息 的 发 布 等 ， 此 功能 是 
同学 C 来 实现 的 。 


2.7.1 登录 首页 


进入 后 台 管理 必须 有 一 个 登录 后 台 的 页 面 ， 如 图 2-10 所 示 为 本 系统 登录 后 台 的 首页 ， 
登录 后 才 可 以 进入 后 台 进 行 管理 。 


管理 员 名 称 : 
管理 员 密码 : 


B c 


图 2-10 ”后台 管理 首页 
下 面 通过 一 段 代 码 进行 讲解 ， 其 代码 (login.php) 如 下 : 


«html» 
<head> 
<title></title> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
<link href="../css/style.css" rel="stylesheet"> 
</head> 
<body bgcolor="#FFFFFF" leftmargin="0" topmargin="0" marginwidth="0" 
marginheight="0"> 
<p>&nbsp;</p> 
<p>&nbsp;</p> 
<p>&nbsp;</p> 
<script language="javascript"> 
function chkinput (form) 

t 

if(form.name.value--"") 
{ 

alert ("请 输入 用 户 名 !") ; 
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form.name.select(); 
return(false); 
} 
if(form.pwd.value--"")( 
alert ("请 输入 用 户 密码 !") ; 
form.pwd.select (); 
return (false); 
} 
return (true); 
</script> 
«form name="forml" method="post" action-"chkadmin.php" 
onSubmit-"return chkinput (this)"» 
«table width-"547" border-"0" align="center" 
cellpadding-"0" cellspacing-"0" id-" 01"> 
«tr» 
«td height-"94" background-"images/default 01.gif"»&nbsp;«/td» 
</tr> 
<tr> 
<td height="160" align="center" background="images/default 02.gif"> 
<table width="83%" height="93" border="0" cellpadding="0" 
cellspacing="0"> 
<tr> 
«td width-"39$" height="30" align="right"> 管 理 员 名 称 : &nbsp;«/td» 


«td widt| 61&"»&nbsp; 
«input name="name" type="text" id-"name"»«/td» 
«/tr» 
«tr» 
«td height-"30" align="right"> 管 理 员 密码 : &nbsp;«/td» 
«td»&nbsp; 
«input name-"pwd" type="text" id-"pwd"»«/td» 
«/tr» 


«tr align="center"> 
«td height-"60" colspan-"2"» 
«input name-"imageField" type-"image" src-"images/btnl.gif" 
width-"79" height-"37" class-"inputl"» 
&nbsp; &nbsp; &nbsp; 
«input name-"imageField2" type- 
"image" src-"images/btn2.gif" width-"79" height-"37" 
onClick-"form.reset();return false;" class-"inputl"» 
«/td» 
«tr 
</table></td> 
«/tr» 
«tr» 
«td height-"23" pbackground-"images/default 04.gif"»«/td» 
«/tr» 
</table> 
</form> 
</body> 
</html> 


272 后 台 首 页 


后 台 首页 不 难 理解 ， 就 是 管理 页 面 的 汇集 ， 在 创建 时 ， 需 要 创建 各 个 区 域 的 PHP 文件 ， 
在 后 台 的 首页 里 展示 的 内 容 ， 是 通过 其 他 主要 页 面 调 入 进来 的 ， 如 left 页 面 ，main 主要 页 


àd 
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面 ， 以 及 bootom 页 面 ， 下 面 将 重点 讲解 后 台 首 页 ， 如 图 2-11 所 示 。 
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图 2-11 后 台 首页 
下 面 通过 一 段 代码 进行 讲解 ， 其 代码 (index.php) 如 下 : 


«html» 
<head> 
<link href-"../css/style.css" rel="stylesheet"> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
<title> 四 公里 社区 网 -- 后 台 管 理 系统 </title> 
</head> 
<frameset rows="*" cols-"1*,1005,1*" framespacing="0" frameborder-"NO" 
border-"0"» 
«frame src-"blank.php" name-"left" scrolling-"NO" noresize» 
«frameset rows-"1005,*" cols-"*" framespacing-"0" frameborder-"NO" 
border-"0"» 
«frameset rows-"94,*,190" cols-"*" framespacing-"0" 
frameborder-"NO" border-"0"» 
«frame src-"top.php" name-"topFrame" scrolling-"NO" noresize» 
«frameset rows-"*" cols-"229,*" framespacing-"0" 
frameborder-"NO" border-"0"» 
«frame src-"left.php" name-"leftFrame" scrolling-"NO" noresize» 
«frame src-"main.php" name-"mainFrame" scrolling-"NO" noresize» 


«/frameset» 
«frame src-"bottom.php" name-"bottomFrame" scrolling-"NO" noresize» 
«/frameset» 
«frame src-"blank.php" name-"right" scrolling-"NO" noresize» 
«/frameset» 

«frame src-"blank.php"» 
«/frameset» 
«noframes»«body» 
X/body»«/noframes» 


</html> 
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2.73 ”后 台 首 页 调 入 的 页 面 
在 后 台 首页 ， 调 入 的 页 面 有 左边 的 页 面 、 主 要 页 


、 底 部 页 面 和 顶部 页 面 等 ， 它 们 都 


是 后 台 管 理 首页 的 核心 ， 下 面 将 分 别 讲解 。 
1. 顶部 页 面 


顶部 页 面 主 要 用 来 显示 导航 信息 还 有 一 些 标志 的 信息 ， 其 功能 相对 来 说 比较 简单 ， 如 
图 2-12 所 示 为 后 台 首 页 顶部 。 
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图 2-12 后 台 项 部 首页 
下 面 通过 一 段 代码 进行 讲解 ， 其 代码 (top.php) 如 下 : 


<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" 
"http://www.w3.org/TR/html4/loose.dtd"» 
«html» 
«head» 
«meta http-equiv-"Content-Type" content-"text/html; charset-gb2312"» 
«link href-"../css/style.css" rel-"stylesheet"» 
</head> 
<body> 
«table width-"1003" height-"94" border="0" align-"center" cellpadding-"0" 
cellspacing-"0"» 
«tr» 
«td width-"1003" height-"94"» 
«img src-"images/banner.gif" width-"1005" height-"94" border-"0" 
usemap="#Map"> 
«/td» 
SETS 
</table> 
<map name="Map"> 
<area shape="rect" coords="820, 64,906, 92" href-"../index.php" target-" parent"> 
<area shape="rect" coords="908, 64, 994, 93" href="login.php" target="_parent"> 
</map> 
</body> 
</html> 


2. 左边 页 面 


左边 页 面 主要 是 免费 信息 显示 方式 、 付 费 信 息 提示 等 功能 ， 方 便 用 户 审核 与 导航 ， 如 
图 2-13 所 示 为 导航 首页 左 音 


> $ 
S 深入 体验 PHP 项 目 开发 W 


W 免费 信息 显示 方式 


* 审核 状态 
C 已 审核 C 未 审核 C 全 部 


信息 类 别 : -求职 信息 [r EF 
m 付费 信息 旺 示 方 式 

* 付费 状态 

C 已 付费 C xum C 全 部 


信息 类 别 : -求职 信息 。 站] EF] 
加 企业 广告 显示 方式 


六 推荐 状态 
C 已 推荐 C 未 推荐 C 全 部 


图 2-13 导航 首页 左边 页 面 
下 面 通 过 一 段 代码 进行 讲解 ， 其 代码 (leftphp) 如 下 : 


«meta http-equiv-"Content-Type" content-"text/html; charset=gb2312"> 
«link href-"../css/style.css" rel-"stylesheet"» 


<style type="text/css"> 

SI 

.style9 (color: #004790} 

TA 

</style> 

<table width="229" border="0" cellspacing="0" cellpadding="0"> 
<tr> 


<td width="229" height="590" align="center" valign="top" background= 
"images/left bg.gif"><table width="222" border="0" cellspacing="0" 
cellpadding="0"> 
<tr> 
«td height-"32" background-"images/gongneng.gif"»&nbsp;«/td» 
«/tr» 
«tr» 
«td height-"95" valign-"top"»«table width-"229" border-"0" 
cellspacing-"0" cellpadding-"0"» 
«tr» 
«td width-"229" height-"34" background-"images/info bg.gif"»&nbsp;«/td» 
«tr 
«tr» 
«td height-"30" align="center" background-"images/bg line.gif"» 
«table width-"229" border-"0" cellspacing-"0" cellpadding-"0"» 
«tr» 
«td height-"55" valign="top"> 
«table width-"229" border-"0" cellspacing-"0" cellpadding-"0"» 
«tr» 
«td height-"30" align="center" valign="middle" background-"images/bg line.gif"» 
«table width-"229" border-"0" cellspacing-"0" cellpadding-"0"» 
«form name-"form3" method-"post" action-"find mianfei.php" 
target-"mainFrame"» 
«tr» 
«td height-"65" align="center"> 
«fieldset style-"height:60;width:210"» 
«legend»* 审核 状态 </legend> 
«input name-"state" type="radio" class-"inputl" value="1"> 


已 审核 
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<input name-"state" type="radio" class-"inputl" value-"0" 


checked» 
未 审核 
«input name-"state" type="radio" class-"inputl" value-"all"» 
全 部 
</fieldset></td> 


«/tr» «tr» 

«td height-"34" align="center" background-"images/info d.gif"> 信 息 类 别 : 
<select name="type"> 

<option value=" 招 聘 


息 ">- 招 聘 信息 </option> 


«option ES 息 "” selected>- 求 职 信息 </option> 
<option 培训 信息 ">- 培 训 信息 </option> 
<option 家 教 信息 ">- 家 教 信息 </option> 
<option 房屋 信息 ">- 房 屋 信息 </option> 
<option 
<option 求购 信息 ">- 求 购 信息 </option> 
<option 出 售 信息 ">- 出 售 信息 </option> 
«option 招商 引资 ">- 招 商 引资 </option> 
<option 公寓 信息 ">- 公 寓 信 息 </option> 
<option value=" 寻 人 / 物 启示 ">- 寻 人 / 物 启 示 </option> 

</select> 

«input type="submit" name-"Submit" value=" 检 索 "></td> 

«/tr» 
«/form» 
«/table» «/td» 
«/tr» 
</table></td> 

</tr> 

</table></td> 

«/tr» 
«tr» 


«td align-"center" valign-"middle"»«table width-"229" border-"0" 
cellspacing-"0" cellpadding-"0"» 
«tr» 
«td width-"229" height-"34" background-"images/info bgl.gif"»&nbsp;«/td» 
«/tr» 
«tr» 
«td height-"30" align="center" background-"images/bg line.gif"» 
«table width-"229" border-"0" cellspacing-"0" cellpadding-"0"» 
«form name-"form4" method-"post" action-"find fufei.php" 
target-"mainFrame"» 
«tr» 
«td height-"65" align="center"> 
«fieldset style-"height:60;width:210"» 
«legend»* 付费 状态 </legend> 
«input name-"payfor" type-"radio" class-"inputl" value="1"> 


已 付费 
«input name-"payfor" type="radio" class-"inputl" value="0" checked» 
未 付费 
«input name-"payfor" type="radio" class-"inputl" value-"all"» 
全 部 
</fieldset></td> 
«/tr» 
«tr» 


«td height-"34" align-"center" background-"images/info d.gif"» 


信息 类 别 : 


«select name-"select"» 


——— —————————————M——— POPE PRINS » 


SS 
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«option value=" 招 聘 信息 ">- 招 聘 信息 </option> 
«option value=" 求 职 信息 ”selected>- 求 职 信息 </option> 
«option value=" 培 训 信 息 ">- 培 训 信息 </option> 
<option value=" 家 教 信息 ">- 家 教 信息 </option> 
<option 信息 ">- 房 屋 信息 </option> 
<option 车 辆 信息 ">- 车 辆 信 息 </option> 
<option value=" 求 购 信 息 ">- 求 购 信 息 </option> 
<option value=" 出 售 信息 ">- 出 售 信 息 </option> 
<option value=" 招 商 引资 ">- 招 商 引 资 </option> 
«option value=" 公 寓 信息 ">- 公 寓 信 息 </option> 
«option value=" 寻 人 / 物 启示 ">- 寻 人 / 物 启示 </option> 
«/select» 
«input type-"submit" name-"Submit2" value=" 检 索 "></td> 

</tr> 

</form> 

</table> 

«/td» 
«/tr» 


</table></td> 
«/tr» 
«tr» 
<td><table width-"229" border-"0" cellspacing-"0" cellpadding-"0"» 
«tr» 
«td width-"229" height-"34" background-"images/info bg?.gif"»&nbsp;«/td» 
«/tr» 
«tr» 
«td height-"30" align-"center" background-"images/bg line.gif"» 
«table width-"229" border-"0" cellspacing-"0" cellpadding-"0"» 
«form name-"form5" method-"post" action-"find gg.php" 
target-"mainFrame"» 
«tr» 
«td height-"65" align="center"> 
«fieldset style-"height:60;width:210"» 
«legend»* 推荐 状态 </legend> 
«input name-"commend" type-"radio" class-"inputl" value-"1"» 已 推荐 
«input name-"commend" type-"radio" class-"inputl" value-"0" 


checked> 未 推荐 
«input name-"commend" type-"radio" class-"inputl" value-"all"» 全 部 
«/fieldset»«/td» 
«/tr» 
«tr» 


«td height-"34" align-"center" 
background-"images/info d.gif"»«input name-"Submit3" type-"submit" 
id-"Submit3" value=" 检 索 "></td> 
«/tr» 
«/form» 
</table> 
</td> 
«/tr» 
</table></td> 
Sen 
«tr»«td»&nbsp;«/td»«/tr» 
«tr» 
«td height-"39" align-"center"»«form name-"forml" method="post" 
action-"release content.php" target-"mainFrame"» 
<input name-"imageField" type-"image" class-"inputl" 
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src-"images/btn fufei.gif" width-"210" height-"39" border="0"> 
«/form»«/td» 
«/tr» 
«tr» 
«td »«/td» 
«/tr» 
«tr» 
«td height-"39" align="center"> 
«form name-"form2" method-"post" action-"advertising.php" 
target-"mainFrame"» 
<input name-"imageField2" type-"image" class-"inputl" 
src-"images/btn guangao.gif" width-"210" height-"39" border-"0"» 
«/form» 
«/td» 
«/tr» 
«/table» 
«/td» 
«/tr» 
«/table» 


2.7.4 付费 供求 信息 


用 户 通 过 导航 区 的 “付费 信息 ”链接 ， 进 入 付费 信息 页 面 ， 填 写 完 需要 发 布 的 付费 信 
息 后 ， 单 击发 布 信息 按钮 ， 程 序 会 先 验证 用 户 输入 的 信息 ， 若 失败 ， 则 返回 信息 发 布 页 面 ， 
并 给 予 相关 的 提示 ; 若 验 证 成 功 则 向 数据 库 插入 记录 ， 完 成 操作 ， 如 图 2-14 所 示 。 
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2-4 ”付费 信息 页 面 


下 面 通过 一 段 代码 进行 讲解 ， 其 代码 (release_ok.php) 如 下 : 


«?php 

include ("../conn/conn.php") ;// 链 接 数 据 库 
$type=$_POST [type] ; // 获 取 数据 类 型 

$flag-$ POST[flag]==""?0:1;// 获 取 付款 状态 
$title=$ POST[title];// 获 取信 息 标题 
$content-$ POST[content];// 获 取信 息 内 容 
$linkman=$ POST[linkman] ;// 获 取 联 系 人 
$days-$ POST[days]; / / 3KIBUR f fe] fe] 
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$tel-$ POST[tel];// 获 取 联系 电话 
$sdate-date ("Y-m-d") ;// 获 取 系 统 时 间 
$showday-date ("Y-m-d", (time ()+3600*24*$days) ) ;// 获 取 有 效 时 间 
$sql-mysql query ("insert into tb leaguerinfo 
(type, title, content, linkman, tel, sdate, showday, checkstate)values('$type', 
'$title','$content','$linkman','$tel','$sdate', '$showday',$flag)"); 
// 将 付费 供求 信息 添加 到 数据 库 
if($sql)t 

echo "«script»alert (' 信 息 发 布 成 功 ! 1); 

parent.mainFrame.location.href-'release content.php';</script>"; 

}else{// 如 果 添 加 操作 失败 ， 则 弹出 提示 信息 

echo "<script>alert (' 信 息 发 布 失败 ! ') ;history.back();</script>"; 
?> 


2.7.5 ”付费 信息 的 管理 


付费 信息 是 本 网 站 的 核心 ， 付 费 管理 是 本 系统 的 最 为 核心 的 功能 ， 如 果 管 理 不 好 ， 会 
出 现 很 多 问题 。 付 费 信息 页 面 如 图 2-15 所 示 。 
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图 2-15 付费 信息 页 面 
下 面 通过 一 段 代 码 进行 讲解 ， 其 代码 (find_fnfeiphp) 如 下 : 


«meta http-equiv-"Content-Type" content-"text/html; charset=gb2312"> 
«link href-"../css/style.css" rel-"stylesheet"» 

«?php 

include ("../conn/conn.php") ;// 连 接 数 据 库 

$state-$ POST[payfor] ;// 获 取 管理 员 选 择 的 付费 状态 

$type=$_POST[select];// 获 取 管 理 员 选择 的 信息 类 别 

if($ POST[select]=="") { 

$state=$ GET[state]; 

$type-$ GET [type]; 


} 
// 如 果 管理 员 选 择 付费 状态 为 全 部 ， 则 查询 管理 指定 信息 类 别 下 所 有 付费 的 信息 
if($state=="all")}{ 

$sgll-mysql query("select count(*) as total from tb leaguerinfo where 
type-'$type' order by id"); 
jelset 
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// 如 果 管 理 员 选 择 付费 状态 “已 付费 ”或 “未 付费 ”状态 , 则 管理 员 指 定 的 条 件 进 行 查询 
$sqll=mysql query("select count(*) as total from tb leaguerinfo where 
type-'$type' and checkstate-$state order by id"); 
H 
$info-mysql fetch array ($sql1);// 执 行 soL 语句 
$total-$minfo[total]; 
$pagesize-4; 
if($total«-$pagesize)( 
$pagecount-1; 
i 
if((Stotal$$pagesize)!-0)( 
$pagecount-intval ($total/$pagesize)-41; 
}else{ 
$pagecount=$total/$pagesize; 
} 
if(($ GET[page])--"")( 
$page=1; 
}else{ 
$page-intval($ GET[pagel); 
} 
if($state--"all")( 
$sql-mysql query ("select * fromtb leaguerinfo where type-'$type' order 
by id limit ".($page-1)*$pagesize.",$pagesize"); 
Jelse( 
$sql-mysql query ("select * from tb leaguerinfo where type-'$type' and 
checkstate-$state order by id limit ".($page-1)*$pagesize.",$pagesize"); 
) 
$info-mysql fetch array ($sql); 
?> 
<table width="776" border="0" cellspacing="0" cellpadding="0"> 
<tr> 
<td height="32" background="images/right line.gif"> 
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; 您 现在 的 位 置 ， 四 公里 社区 网 
&nbsp; &gt; gnbsp; 后 台 管 理 系统 </td> 
«/tr» 
«tr» 
«td height-"32" background-"images/right top.gif"»&nbsp;«/td» 
«/tr» 
«tr» 
«td height-"488" align-"center" valign-"top" 
background-"images/right middle.gif"» 
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; 
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; 
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; 
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; 
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; 
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; 
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; 
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; 当前 信息 类 别 : &nbsp; I 
«span class-"stylell"»&nbsp;«?php echo $type;?»&nbsp;«/span»] «br» 
«table  width-"709"  border-"0"  cellpadding-"0"  cellspacing-"1" 
bgcolor-"£FFCC33" 
«tr alig center" bgcolor-"£FFCC33"» 
«td width="76"> 信 息 标题 </td> 
«td width="204"> 信 息 内 容 </td> 
«td width="65"> 联 系 人 </td> 
«td width="88"> 联 系 电话 </td> 
«td width="79"> 发 布 日 期 </td> 


àd 


V 
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«td width="72"> 截 止 日 期 </td> 
«td width="54"> 审 核 状 态 </td> 
«td width="62"> 操 作 </td> 
«/tr» 
«?php 
if ($info){ 
do{ 
if ($info[checkstate]==1) ( 
$statel=" 已 付费 "; 
}else{ 
$statel=" 未 付费 "; 
) 
2> 
<tr bgcolor="#FFFFFF"> 
<td>&nbsp;<?php echo $info[title];?></td> 
«td width="204">&nbsp;<?php echo $info[content];?»«/td» 
«td»&nbsp;«?php echo $info[linkman];?»«/td» 
«td»&nbsp;«?php echo $info[tel];?»«/td» 
«td»&nbsp;«?php echo $info[sdate];?»«/td» 
«td»&nbsp;«?php echo $info[showday];?»«/td» 
«td align="center" class-"stylell"»«?php echo $statel;?»«/td» 
«td align="center" bgcolor-"£FFFFFFE"» 
«a href-"statefu ok.php?id-«?php echo $info[id];?»&type- 
<?php echo $type;?»&state-«?php echo $state;?>"> 审 核 </a> 
«a href-"fudel ok.php?id-«?php echo $info[id];?»&type- 
<?php echo $type;?»&state-«?php echo $state;?>"> 删 除 </a></td> 
«/tr» 
<?php 
)while($info-mysql fetch array($sql)); 
?> 


<tr bgcolor="#FFFFDD"> 
«td height-"22" colspan-"8" align="right"> &nbsp; 共有 &nbsp; 
«?php 
echo $total; 
?» 
&nbsp: 条 &nbsp; 每 页 显示 &nbsp;<?php echo $pagesize;?»&nbsp; 4&nbsp; b 
&nbsp;«?php echo $page;?>&nbsp; 页 / 共 &nbsp;<?php echo $pagecount; ?»&nbsp; Ji 


«?php 
if ($page»-2)( 
2> 
<a href-"find fufei.php?type-«?php echo $type;?>&state= 
<?php echo $state;?»&page-1l" title=" 首 页 "></a> 
«a href-"find fufei.php?type-«?php echo $type;?»&state- 
<?php echo $state;?»&page-«?php echo $page-1;?»" title=" 上 一 页 "></a> 
<?php 
} 
if ($pagecount<=4) { 
for ($i=1; $i<=$pagecount; $i++) { 
WES 
«a href-"find fufei.php?type-«?php echo $type;?»&state- 
<?php echo $state;?»&page-«?php echo $i;?»"»«?php echo $i;?»«/a» 
«?php 
) 
teisei 
for ($i=1; $i<=4; $i++) { 
px 
«a href-"find fufei.php?type-«?php echo $type;?»&state- 
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<?php echo $state;?»&page-«?php echo $i;?»"»«?php echo $i;?»«/a» 
<?php )?» 
«a href-"find fufei.php?type-«?php echo $type;?»&state- 
<?php echo $state;?»&page-«?php echo $page-1;?»" title=" 下 一 页 "></a> 
«a href-"find fufei.php?type-«?php echo $type;?»&state- 
<?php echo $state;?»&page-«?php echo $pagecount;?»" title=" 尾 页 "></a> 
<?php }?> 
&nbsp; </td> 
«/tr» 
«?php 
}else{ 
po 
«tr align="center" bgcolor-"£FFFFFF"» 
«td colspan="8"> 对 不 起 ， 您 检索 的 信息 不 存在 ! </td> 
</tr> 
<?php 


</table> 
</td> 
</tr> 
<tr> 
<td height="32" background="images/right bottom.gif">&nbsp;</td> 
</tr> 
</table> 


2.7.6 ”付费 信息 审核 


经 过 审核 的 信息 ， 说 明 该 信息 为 已 付款 信息 。 如 果 企 业 或 个 人 用 户 已 提供 供求 信息 ， 
但 未 直接 付费 ， 需 要 后 期 付费 ， 管 理 员 对 它 进行 审核 ， 经 过 审核 的 信息 可 在 前 后 台 显 示 ， 
其 代码 (staefu_ok.php) 如 下 : 


<?php 
include ("../conn/conn.php");// 连 接 数 据 库 
$id=$ GET[id];// 获 取 ID 号 
$type=$_GET[type];// 获 取信 息 类 型 
$state-$ GET[state];// 获 取信 息 付费 状态 
$sql=mysql query ("update tb leaguerinfo set checkstate-1 where id=$id"); 
// 更 新 
if($sql)t 
echo "«script»alert (' 该 信息 已 经 通过 审核 ! // 弹 出 信息 '); 
window.location.href-'find fufei.php?type=$type&state=$state';</script>"; 
B 
else( 
echo "«script»alert (' 该 信息 审核 操作 失败 ! ') ;history.back();«/script»"; 


B 
?» 
«meta http-equiv-"Content-Type" content-"text/html; charset-gb2312"» 


2.77 ”付费 信息 删除 


当 付费 信息 达到 一 定 的 阶段 后 ， 可 以 将 其 删除 ， 删 除 的 方法 十 分 简单 ， 下 面 通过 一 段 
代码 进行 讲解 如 何 实现 删除 付费 信息 的 ， 其 代码 (fudel ok.php) 如 下 : 


————————————————————— PX 65 | 
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«?php 
include ("../conn/conn.php") ;// 连 接 数 据 库 
$id-$ GET[id];// 获 取 ID 号 
$type=$_GET [type] ; // 获 取信 息 类 型 
$state-$ GET[state];// 获 取信 息 付 费 状态 
$sql-mysql query("delete from tb leaguerinfo where id=$id") ;// 删 除 对 应 的 信息 
if($sql)t 
echo "<script>alert (' 该 信息 已 经 删除 ! "); 
window.location.href-'find fufei.php?type-$type&state-$state';«/script»"; 
// 弹 出 提示 信息 


else( 

echo "<script>alert (' 该 信息 删除 操作 失败 ! ') ;history.back();«/script»"; 
// 删 除 失败 提示 信息 
} 


2> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 


28 W iX 


今天 看 到 胜利 的 曙光 了 ， 最 后 的 项 目测 试 工作 由 我 来 完成 。 在 此 我 将 项 目 命名 为 
“02shequ”。 


2.8.1 系统 运行 浏览 


系统 调试 一 次 性 通过 ， 其 界面 如 图 2-16 所 示 。 班 长 兴奋 之 余 宣 布 晚 上 聚餐 ， 为 我 们 过 
去 一 段 时 间 的 忙碌 做 奖赏 。 
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注意 : 本 项 目的 具体 代码 保存 在 附 赠 光盘 的 “第 2 章 ” 目 录 下 ， 工 程 名 称 为 “02shequ”。 
请 读者 首先 将 其 复制 到 硬盘 中 ， 去 掉 文 件 的 只 读 属 性 。 


我 发 现 项 目测 试 最 简单 了 , 我 用 了 三 天 的 时 间 , 经 过 反 反 复 复 地 测试 ， 发 现 运行 完全 正 
常 。 我 们 说 正常 是 没 用 的 ， 还 需要 交付 客户 ， 让 他 们 来 验收 。 
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还 有 一 个 月 进入 新 的 一 年 了 ， 我 充满 了 期 待 。 在 寒 风 疗 阐 的 冬季 ， 我 穿梭 在 城市 中 ， 
想到 项 目 完成 了 ， 项 目的 成 功 ， 意 味 着 我 们 的 操作 水 准 以 团队 的 形式 上 升 了 一 层 ， 真 值得 
高 兴 。 

我 们 的 站 点 进入 了 公测 阶段 ， 反 映 良好 ， 估 计 不 用 做 什么 修改 ， 就 可 以 正式 运营 了 。 

在 后 期 维护 上 ， 我 们 也 安排 了 分 工 ， 留 下 了 同学 A 的 电话 作为 全 天 候 服务 热线 。 而 我 、 
同学 B、 同 学 C 则 开始 为 系统 升级 做 准备 ， 并 考虑 系统 优化 等 方面 的 问题 。 


2.8.3 总 结 


项 目前 后 经 过 一 个 月 时 间 开 发 完成 ， 这 次 经 历 在 我 脑海 中 留 下 恒久 的 痕迹 。 这 不 只 是 
因为 开发 过 程 中 遇 到 的 困难 有 惊 无 险 ， 而 是 因为 这 是 我 第 一 个 赢利 性 的 项 目 。 为 了 积累 更 
多 的 经 验 ， 结 合 这 次 项 目的 经 历 我 做 了 一 个 深刻 的 总 结 。 

1) 数据 库 表 分 类 的 重要 性 

这 次 的 项 目 是 一 个 社区 网 站 ， 里 面 保存 着 不 同 的 信息 ， 开 发 这 样 的 项 目 ， 用 户 需要 善 
于 分 类 ， 将 数据 库 表 分 得 越 细 越 好 ， 然 后 通过 表 里 的 关键 字段 让 表 与 表 之 间 产 生 关系 ， 这 
样 可 以 方便 地 使 用 数据 库 表 ， 方 便 日 后 开发 。 

2) 开发 要 规范 

在 这 个 项 目的 开发 过 程 中 ， 很 多 地 方 不 规范 ， 应 用 了 陈旧 的 技术 ， 如 DIV+CSS 样式 这 
种 有 利 的 样式 没有 在 这 个 方面 体现 ， 由 于 团队 成 员 项 目 操作 经 验 过 少 ， 在 开发 过 程 中 为 了 
赶 速度 ， 没 有 及 时 优化 ， 也 没有 让 整个 项 目 规范 起 来 。 

3) 对 于 相同 的 功能 ， 只 编写 一 次 

开发 类 似 的 网 站 ， 难 免 有 许多 相同 的 功能 ， 如 导航 信息 、 头 部 信息 、 版 权 信息 、 数 据 
库 配 置信 息 ， 这 些 程序 都 是 要 被 调用 很 多 次 。 对 于 没有 经 验 的 人 来 说 ， 很 可 能 需要 一 次 ， 
会 编写 一 次 。 实 际 上 ， 用 户 应 该 分 开 编写 这 些 不 同 的 代码 ， 用 单独 的 PHP 文件 保存 起 来 ， 
需要 时 将 其 调用 即 可 。 这 样 编写 的 好 处 ， 一 来 可 以 提升 工作 效率 ， 二 来 可 以 加 快运 行 速 度 ， 
三 是 降低 对 服务 器 的 要 求 。 
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4) 鼓励 合作 伙伴 

在 项 目 中 没有 英雄 ， 伙 伴 一 般 是 用 来 沟通 协调 的 ， 尤 其 是 刚 成 立 的 团队 ， 大 家 都 知道 
团队 的 重要 性 ， 但 是 真正 落实 到 项 目 上 去 ， 很 容易 产生 互相 抱怨 的 状态 ， 这 是 很 危险 的 ， 
对 于 团队 成 员 要 互相 沟通 ， 互 相 表 定 ， 互 相 赏 识 ， 只 有 这 样 ， 才 能 完成 共同 的 目标 ， 否 则 
项 目 有 可 能 早死 胎 中 。 
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每 个 人 都 有 一 本 相册 ， 用 来 保存 自己 的 过 去 、 朋 友和 
亲人 ， 无 论 是 前 卫 的 80 后 、90 后 ， 还 是 传统 至 上 的 70 
后 ， 都 会 将 过 去 的 精彩 瞬间 记录 在 厚 厚 的 相册 里 。 

随 着 科技 的 发 展 ， 越 来 越 多 的 人 喜欢 把 相册 挂 在 网 络 
空间 里 ， 因 此 ， 有 许多 大 型 网 络 公 司 开发 了 网 络 相 册 ， 如 
腾讯 、 网 易 和 新 浪 等 。 如 何 开发 一 个 属于 自己 的 电子 相册 
呢 ? 在 本 章 中 读者 将 会 学 到 关于 相册 开发 的 知识 ， 为 以 后 
深入 地 学 习 打 下 坚实 的 基础 。 


V 深入 体验 PHP 项 目 开发 
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3.4 美好 的 记忆 


双 选 会 临近 ， 我 们 也 陆续 开始 找 工作 了 ， 心 里 有 些 迷 茫 和 浮躁 。 我 做 好 了 两 手 准 备 ， 
决定 边 学 习 深造 ， 边 投 简历 。 在 这 个 初冬 的 季节 ， 我 终于 被 一 家 中 型 的 开发 公司 录取 。 此 
公司 主 营 Web 开发 ， 是 当地 小 有 名 气 的 建站 企业 之 一 。 试 用 期 两 个 月 ， 试 用 期 过 后 将 签署 
正式 劳动 合同 。 


3.1.1 项 目 来 源 
D 200612919, 58 


不 觉 间 毕业 进入 职场 已 经 一 个 月 了 ， 我 整 天 无 聊 地 做 着 公司 网 站 维护 的 活 。 而 同 办 公 
室内 的 其 他 同事 都 有 项 目 在 身 ， 根 本 无 暇 关照 我 ， 只 有 在 午饭 时 候 才 会 偶尔 修 上 几 句 。 但 
是 看 着 他 们 忙碌 的 样子 ， 我 很 是 羡慕 ， 心 中 希望 自己 也 能 够 和 他 们 一 样 做 项 目 。 

今天 项 目 经 理 DP 将 我 叫 到 了 办 公 室 ， 说 现在 有 一 个 项 目 需要 我 参与 完成 : 给 某 影视 学 
院 活动 中 心 制作 一 个 相册 管理 系统 ， 并 且 声 明 这 个 项 目 作 为 考核 我 的 一 个 测试 ， 希 望 我 好 
好 干 。 


3.42 ”组建 团队 
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虽然 项 目 不 大 ， 但 是 因为 关系 到 我 能 和 否 通过 考核 ， 所 以 我 相当 重视 。 为 了 开发 这 个 项 
目 ， 我 和 同事 组 建 了 一 个 小 小 团队 。 团 队 成 员 如 下 。 

同事 A: 

来 自 美丽 的 湘西 ， 中 专 毕业 后 游 遍 了 国内 的 大 好 河山 。 后 来 不 知道 什么 原因 喜欢 上 了 
编程 ， 喜 欢 购买 计算 机 书籍 ， 对 各 个 技术 进行 研究 ， 可 惜 没有 名 师 指导 ， 导 致 学 的 东西 杂 
而 不 精 ， 项 目的 核心 代码 他 是 难以 胜任 了 ， 但 做 策划 还 是 可 以 完全 胜任 。 

任务 : 负责 项 目 规划 ， 撰 写 系统 设计 规划 书 。 

同事 B: 

公司 的 元 老 级 程序 员 , 工作 经 验 丰 富 , 开发 过 大 小 上 百 个 项 目 。 精通 C 语 言 、 ASP、 JSP, 
甚至 手机 操作 系统 Android 和 iPhone 也 有 所 涉 猫 。 

任务 : 负责 需求 分 析 和 数据 库 设计 。 

同事 C: 

一 个 充满 阳光 的 帅哥 ， 也 是 我 们 团队 的 活宝 。 平 常 喜欢 点 评 美女 ， 同 时 也 是 一 个 运动 
狂人 ， 喜 欢 惊险 刺激 的 户外 运动 。 在 他 的 感染 下 ， 整 个 团队 永远 充满 了 笑容 。 更 难得 的 是 ， 
他 特别 精通 PHP 技术 ， 几 乎 能 够 背 过 每 一 个 函数 的 具体 语法 和 用 法 。 

任务 : 负责 设计 后 台 管 理 模块 和 用 户 管理 模块 。 
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当然 还 有 我 负责 系统 整体 框架 设计 和 前 台 相 册 展 示 ， 并 协调 项 目 中 各 个 模块 的 进展 。 
具体 职能 结构 如 图 3-1 所 示 。 


同事 A 同事 B 
项 目 规划 数据 库 设 计 
前 台 相 册 设 计 
框架 设计 
同事 C 
后 台 设 计 


3-1 职能 结构 图 


整个 项 目的 具体 操作 流程 是 : 项 目 规划 一 数据 库 设 计 一 框架 设计 一 系统 信息 管理 、 用 
户 管理 、 前 台 相册 展示 。 


3.4.3 小 会 议 
今天 DP 给 我 打 了 电话 ， 说 客户 希望 我 们 能 在 元 旦 之 前 将 这 个 项 目 完成 ,因为 元 旦 要 把 


这 个 系统 发 布 在 服务 器 上 ， 供 影视 学 院 活动 中 心 使 用 。 我 接 到 这 个 消息 ， 迅 速 给 我 们 的 成 
员 打 了 电话 ， 并 开 了 一 个 简短 的 临时 会 议 ， 保 证 在 元 旦 之 前 完成 任务 。 并 且 大 家 一 致 商讨 


示 相 册 管 理 ， 以 图 片 缩 略 图 技术 为 主 。 
大 家 一 致 提议 同事 A 尽快 作出 规划 书 ， 后 续 工 作 将 以 规划 书 为 基础 进行 扩展 。 


3.2 ”系统 概述 和 总 体 设计 
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今天 天 气 不 错 ， 我 脑海 中 还 是 昨天 关于 项 目的 会 议 。 并 且 还 清晰 地 记得 会 上 说 要 开发 
一 个 漂亮 的 相册 管理 系统 首先 需要 进行 系统 需求 分 析 和 总 体 设计 ， 分 析 系 统 的 使 用 对 象 和 
用 户 需求 ， 设 计 系统 的 体系 结构 和 数据 库 表 结构 ， 决 定 使 用 的 开发 工具 和 后 台数 据 库 ， 规 
划 项 目的 开发 进度 等 。 看 来 这 个 项 目的 第 一 步 还 是 和 以 前 做 过 的 项 目 一 样 ， 要 做 项 目 规划 书 。 

同事 A 很 快 做 出 了 项 目 规划 书 ， 整 个 规划 书 分 为 以 下 两 个 部 分 。 

ü ”系统 需求 分 析 

O “系统 运行 流程 

相册 管理 系统 的 用 户主 要 是 针对 影视 学 院 的 学 生 ， 具 体 功能 如 下 : 
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1) 基本 信息 管理 功能 模块 

基本 信息 管理 模块 的 主要 功能 包括 : 相片 分 类 展示 、 最 新 上 传 、 热 门 图 片 等 。 

2) 用 户 管理 

这 是 一 个 大 型 的 相片 管理 系统 ， 需 要 多 个 用 户 对 它 进 行 管理 ， 超 级 管理 员 可 赋予 其 他 
管理 员 权限 ， 让 他 们 只 能 操作 部 门 功能 。 

3) 系统 设置 

系统 设置 是 本 系统 的 核心 ， 管 理 员 可 以 凭借 自己 的 权限 对 系统 进行 设置 ， 如 常规 设置 、 
管理 员 设置 、 修 改 密码 和 后 台 任务 。 

根据 需求 分 析 中 总 结 的 用 户 需求 设计 系统 的 体系 结构 ， 如 图 3-2 所 示 。 


相册 管理 系统 说 “系统 设置 ”上 


一 一 一 | 用 户 管理 


图 3-2 相册 管理 模块 
3.3 ”数据库 设计 
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本 项 目 数据 库 的 开发 主要 包括 后 台数 据 库 的 建立 、 维 护 以 及 前 端 应 用 程序 的 开发 三 个 
方面 。 数 据 库 设计 是 此 相册 管理 系统 的 基础 ， 是 整个 系统 设计 开发 的 一 个 重要 组 成 部 分 。 
因此 在 本 阶段 ， 由 最 有 经 验 的 同事 B 来 负责 数据 库 的 开发 。 


3.3.1 数据 库 设 计 
由 需求 分 析 的 规划 可 知 整个 项 目 对 象 有 三 种 信息 ， 所 以 对 应 的 数据 库 也 需要 包含 这 三 


种 信息 ， 从 而 系统 需要 包含 三 个 数据 库 表 ， 分 别 是 : 
O meu admin: 用 户 信息 表 ; 
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口 meu albums: 相册 目录 表 ; 

口 meu imgs: 图 片 信息 表 。 

同事 B 给 出 了 具体 数据 库 表 的 书面 文件 如 下 。 

(1) 用 户 信息 表 meu_admin， 用 来 保存 管理 用 户 的 信息 ， 表 结构 如 表 3-1 所 示 。 


表 3-1 meu_admin 表 


字段 类 型 整理 Et nu S 
int11) Ei 
usemame 。 varcharf50) uff general ci 
userpass — varchar50) uff8 general ci 

create tme int(11) 


(2) 相册 目录 表 meu_albums， 用 来 保存 目录 信息 ， 如 表 3-2 所 示 。 


表 3-2 meu_albums 表 


Dj Di ni 


字段 类 型 整理 属性 won RU "5^ 
到 int(11) Li auto increment. 
name varchar(50) uffé general ci Ei 
cover int(11) ES o 
create time. int(11) S 0 
private tinyint(1) m 0 
desc tet w8 general ci * 


(3) 图 片 信息 表 meu_imgs， 用 来 保存 图 片 信息 ， 如 表 3-3 所 示 。 


表 3-3 meu_imgs 表 


字段 天 型 整理 属性 nu RU Sh 
i m11) E auto increment 
album smallint) Li 

name varchar(100) wff8 general ci € 

dir varchar(10) — uff8 general ci € 

pickey varchar(32) — uffà general ci z 

ext varchar(10) — uff8 general ci Lj 

status. tinyin) mo 

hits inta) S o 

create time — int(11) ri po 

private tinyint(1) mS 0 

private pass varchar(50)  uff8 general ci € 

author int11) a 0 

desc text wtf general ci * 
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当 创 建 好 了 数据 库 后 ， 用 户 需要 编写 一 个 数据 库 信息 表 ， 供 程序 员 编写 调用 ， 下 面 通 
过 一 段 代码 进行 讲解 ， 其 代码 (config.php) 如 下 : 
«?php 


$db config = array 
( 


'adapter' => 'mysql',// 数 据 库 适 配器 
'"host' => 'localhost',// 数 据 库 连接 地 址 
'port' => '3306',/ / GR FEX O 


'dbuser' => 'root',// 数 据 库 用 户 名 
'dbpass' => '1234',// 数 据 库 密码 
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'dbname' => 'meiupic'，,// 数 据 库 名 称 
'pconnect' => false, // 数 据 库 是 否 持久 连接 
'charset' => "utf8',// 数 据 库 字符 集 选 择 


"pre” => "meu ” 


3.3.3 ”系统 配置 信息 


系统 配置 信息 ， 主 要 是 用 来 保存 系统 信息 的 名 称 、 地 址 等 一 系列 信息 ， 这 些 信 息 ， 在 
后 台 可 以 更 改 ， 前 台 会 调用 里 面 的 变量 ， 用 来 正常 显示 ， 下 面 通过 一 段 代 码 进行 讲解 ， 其 
配置 代码 (setting.php) 如 下 : 


<?php 

$setting['site title'] = ' 西 南 传媒 大 学 影视 学 院 活动 中 心 ';// 设 置 名 称 
$setting['site keyword'] = '';//W E 

$setting['site description'] = ''; 

$setting['url'] = 'http://127.0.0.1/meiupic/';//W Edi 
$setting['open pre resize'] - false; 
$setting['resize img width'] = '1600';// 设 置 图 片 宽 
$setting['resize img height'] = '1200';// 设 置 图 片 高 
$setting['resize quality'] = "100';// 设 置 图 片 质量 
$setting['demand resize'] = false;// 设 置 大 小 
$setting['imgdir type'] = '2'; 

$setting['size allow'] = "1024000';// 人 允许 大 小 
$setting['pageset'] = '15';// 页 面 记录 数 
$setting['open photo'] = true;// 打 开 图 片 
$setting['gallery limit'] = '60';// 设 置 图 片 显 示 限 制 
$setting['access ctl'] = false; 

$setting['access domain'] = '127.0.0.1';// 服 务 器 地 址 
$setting['open watermark'] false; 

$setting[ 'watermark path'] Dr 
$setting['watermark pos'] - 0; 

2> 


2006 第 (2 月 10 日 &, 数据 库 很 重要 


今天 终于 完成 了 数据 库 的 设计 工作 和 数据 库 配 置信 息 的 编码 工作 ， 这 样 整 个 前 期 的 系 
统 配 置 工作 结束 。 在 过 去 五 天 里 ， 我 深刻 地 体会 到 了 数据 库 工作 的 重要 性 ， 所 以 决定 将 必 
要 的 数据 库 配 置信 息 编写 在 相应 的 PHP 文件 里 ， 这 样 可 以 加 大 开发 的 速度 ， 也 可 以 让 整个 
项 目 结构 更 清晰 ， 利 于 扩展 。 接 下 来 就 可 以 进入 具体 的 编码 阶段 了 。 


34 前 台 设 计 


我 们 的 项 目 步 入 编码 阶段 ， 按 照 预先 的 规划 ， 首 先进 行 前 台 界 面 的 设计 和 编码 工作 。 
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这 个 阶段 的 工作 是 由 我 来 完成 的 ， 其 实 这 些 工 作 很 简单 ， 我 只 需 根据 前 期 规划 和 数据 库 分 
析 ， 明 确 系统 主页 和 各 个 附 页 所 要 显示 的 内 容 后 ， 就 可 以 很 有 目的 性 地 进行 设计 工作 和 编 
码 工作 了 。 


3.4.1 首页 的 实现 


首页 是 浏览 者 进入 系统 的 第 一 个 印象 ， 进 入 首页 浏览 者 看 到 什么 对 于 吸引 访问 量 至 关 
重要 ， 一 个 好 的 首页 效果 往往 能 吸引 住 用 户 。 如 图 3-3 所 示 为 本 系统 首页 。 
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图 3-3 系统 首页 


下 面 通过 一 段 代码 来 讲解 系统 首页 的 实现 ， 其 代码 (index.php) 如 下 : 
<?php 
error_reporting (E_ERROR) ;// 返 回 错误 报告 
if (PHP VERSION >= "5.1.0") {// 判 断 P 版 本 
date default timezone set ( 'Asia/Shanghai' ); 


) 

// 判 断 数据 库 类 型 

if(!file exists('conf/config.php') || !file exists('conf/setting.php'))( 
exit; 

} 

header("Content-type: text/html; charset=utf-8") ;// 设 置 头 部 信息 

define('Version','1.1');// 设 置 版 本 

define('FCPATH', FILE ); 

define ('ROOTDIR' , dirname (FCPATH) .'/');// 设 置 路 径 

require once('conf/setting.php');// 调 入 需求 页 面 

require once('conf/config.php'); 

// 定 义 基本 数据 

define('COREDIR',ROOTDIR.'core/'); 

define('LIBDIR',COREDIR.'libs/'); 

define('INCDIR',COREDIR.'include/'); 

define('CTLDIR',COREDIR.'ctls/'); 

define ('VIEWDIR',COREDIR. 'views/') 7;// 图 片 

define ('MODELDIR',COREDIR. 'models/') ;模型 


—Ó— ——————————— a » 
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define ('DATADIR' , ROOTDIR.'data/');// 数 据 资料 


define('SITE URL',$setting['url']);// 地 址 
define('PAGE SET',$setting['pageset']);// 页 面 保存 
require once (INCDIR.'base.php');// 调 入 页 面 
require once (INCDIR.'func.php');// 调 入 页 面 

run(); 

2> 


在 本 系统 的 首页 中 ， 其 实现 技术 比较 简单 ， 涉 及 的 都 是 基本 的 动态 网 页 技术 ， 只 是 简 
单 地 把 相关 功能 页 面 通过 首页 进行 了 调 入 处 理 ， 相 信 读 者 一 读 便 懂 。 


3.4.2 首页 涉及 的 代码 


首页 调用 数据 库 配 置信 息 表 ， 然 后 调用 系统 配置 ， 其 次 还 调用 了 base php 和 func.php， 
下 面 通过 代码 对 它们 进行 讲解 。 


1. 页 面 最 基础 的 信息 处 理 


在 页 面 中 ， 有 相片 的 管理 和 分 类 都 需要 处 理 ， 如 导航 等 功能 的 实现 ， 都 离 不 开 这 个 文 
件 ， 下 面 通过 一 段 代码 进行 讲解 ， 其 代码 (basephp) 如 下 : 


«?php 
// 处 理 数据 的 方法 
function &db($name = 'default',$config = '')( 
global $db_config;// 全 局 变量 
static $database = array();// 定 义 静态 数据 变量 
if(!isset($database[$name]))( 
if($name -- 'default')( 


$config = $db config;// 调 用 数据 库 配 置 


} 
require once (LIBDIR.'db.class.php');// 调 入 页 面 
$database[$name] =& new db($config); 
} 
return $database[$name]; 


} 
// 设 置 数据 模型 
function &load model ($model) {// 装 载 模 型 
static $models = array();// 设 置 模型 
if(!isset($models[$model]))( 
$modelPath = MODELDIR. $model.' .php';// 模 型 设置 
if(file exists ($modelPath)) {// 设 置 文 件 
require once (INCDIR.'modelfactory.php');// 调 用 页 面 
require once ($modelPath) ;// 需 求 配置 
Jelse( 
exit('Can not load model:'.$model); 
} 
$models[$model] -& new $model; 
} 
return $models [$model]; 


H 
// 获 取 输出 量 
function &get output ()( 
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static $output = array(); 
if(!isset(Soutput[0]))( 
require once (LIBDIR.'output.class.php');// 调 用 配置 
$output [0] =& new output(); 

} 

return $output[0]; 


) 
// 运 行 系统 的 检测 
function run()( 
global $setting;// 全 局 变量 
$ctl = isset($ GET['ctl'])?$ GET['ctl' 


:'default'; 


$act = isset($ GET['act'])?$ GET['act']:'index'; 

if(!$setting['open photo'] && $ctl != 'photo' && $act !- 'resize')( 
header('Location: admin.php'); 
exit; 


) 
if (file exists (CTLDIR.'front/'.$ctl.'.php'))( 
require once (INCDIR. ' frontpage.php') ;// 调 用 页 面 文件 
require once(CTLDIR.'front/'.$ctl.'.php'); 
define('IN CTL',$ctl); 
define('IN ACT',$act); 
$controller - new controller(); 
if (is callable (array (&$controller,$act)))( 
call user func (array (&$controller, $act)); 
}else{ 
showInfo('404 not found! ' ,false) ;// 错 误 配 置信 息 
} 
Jelse( 
showInfo('404 not found! ' ,false) ;// 错 误 配 置信 息 
) 


) 

// 用 户 管理 

function run admin(){ 
$ctl = isset($ GET['ct1'])?$ GET['ct1']:'default'; 
$act = isset($ GET['act'])?$ GET['act']:'index'; 


if (file exists (CTLDIR.'admin/'.$ctl.'.php'))( 
require once (INCDIR. 'adminpage.php'); / / VÀ JH EFE Ifi 
require once(CTLDIR.'admin/'.$ctl.'.php'); 
define('IN CTL',$ctl); 
define('IN ACT',$act); 
$controller = new controller();// 内 容 
if (is callable (array (&$controller, $act))){ 

call user func (array (&$controller, $act)); 

}else{ 


showInfo('404 not found! ', false);// 提 示 错 误 信 息 
} 
}else{ 


showInfo('404 not found! ' ,false) ;// 提 示 错 误 信息 
} 


2. 操作 提示 
在 这 个 页 面 中 ， 主 要 是 处 理 前 台 的 一 些 操作 提示 ， 这 个 页 面 调用 其 他 功能 页 面 完成 分 
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类 、 分 页 的 功能 ， 其 代码 (funcphp) 如 下 : 


«?php 
// 设 置 数据 模型 
function get basepath (){ 
if ($dir = trim(dirname($ SERVER['SCRIPT NAME']), 'V,/')) í 
$base path - "/$dir"; 
$base path .= '/'; 
) else ( 
$base path = '/'; 
H 
return $base path; 
H 
function redirect ($c)( 
Qob clean(); 
header("Location: $c"); 
exit(); 
} 
function redirect c($ctl,$act-'index')( 
Qob clean(); 
header("Location: admin.php?ctl-$ctl&act-$act"); 
exit(); 


} 

// 设 置 数据 缓存 

function where is tmp(){ 
$uploadtmp-ini get('upload tmp dir'); 
Senvtmp- (getenv (' TMP') ) ?getenv (' TMP') :getenv (' TEMP') ; 
if (is dir($uploadtmp) && is writable($uploadtmp))return $uploadtmp; 
if (is dir($envtmp) && is writable(S$envtmp))return $envtmp; 
if(is dir('/tmp') && is writable('/tmp'))return '/tmp'; 
if(is dir('/usr/tmp') && is writable('/usr/tmp'))return '/usr/tmp'; 
if(is dir('/var/tmp') && is writable('/var/tmp'))return '/var/tmp'; 
return "."; 


) 
// 设 置 图 片 数 据 
function imgSrc ($img)( 
return 'data/'.$img; 
5 
function mkImgLink ($dir, $key, $ext, $size='big'){ 
if ($size=='orig'){ 
return 'data/'.$dir.'/'.$key.".".$ext; 
) 
return 'data/'.$dir.'/'.$key.' '.$size.'.'.$ext; 


) 

// 获 取 更 新 的 数据 
function get updir name (St) { 

switch($t)( 
case TY 

$name 
break; 
case T24: 

$name 
break; 

default: 

$name 


Li 


date('Ymd'); 


date('Ym'); 


date('Ymd'); 
H 
return $name; 
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// 页 面 显 示 
function pageshow ($total,$page,$url-'',$pageset-5)( 
$ppset - ""; 
if($total»0)( 
if ($page<1 || $page--"") 
$page-1; 
if($page»$total) 
$page-$total; 
$ppset-'«span class-"pageset total"> 共 ' .Stotal-' 页 </span> '; 
if ($page>1) 
$ppset.-'«ahref-"'.str replace('[fpagef]','1',$url).'"5&lt;&lt;«/a» 
X«ahref-"'.str replace(' [#page#]', ($page-1),$url).'" class-"pre page"5&lt;«/a» '; 
if ((S$page-$pageset)»1) ( 
Sppset-="<a href="" str replacel(' tipage#]", "I", Sur) "ST</a> ..- "7 
for ($i=$page-$pageset; $i<$page; $i++) { 
$ppset.-'«a href-"'.str replace('[fpagef]',Si,$url).'"»'.$i.'«/a» '; 
) 
) 
eset 
for ($i=1; $i<$page; $i++) { 
$ppset.-'«a href-"'.str replace('[#page#]"',$i,$url).">'.$i.'</a> '; 
// 取 代 


) 
} 
$ppset.-"«a href=\"".str replace ('[#page#]',$page, $url) ."\" 
onclick=\"return false\" class=\"current\">$page 
Ea WP 
if ( ($page+$pageset)<$total) { 
for ($i-$page*1; $i«- (Spage*$pageset) ;Si++){// 页 面 设置 
$ppset.-'«a href-"'.str replace('[fpagef]',$i,Surl).'"»'.$i.'«/a» '; 
) 
$ppset.-' ... «a href-"'.str replace('[fpagef]',$total,S$url).'"»'.$total.'«/a» '; 
) 
else( 
for($i-$page*1;$i«-$total;$i«4)( 
$ppset.-'«a href-"'.str replace('[fpagef]',$i,Surl).'"»'.$i.'«/a» '; 
) 
) 


if ($page«$total) // 判 断 
$ppset.-' «a href-"'.str replace ('[#page#]', ($page*1),$url).'" 
class-"next page"»5&gt; </a> 
«a href-"'.str replace('[fpagef]',S$total,Surl).'"»&gt;&gt;«/a»'; 
return $ppset; 


} 
else( 
return '«span class-"pageset total"> 共 0 页 </span>';// 显 示 页 面 
i 
5 
function showInfo($message,$flag = true,$link = '',$target = ' self') 
{// 显 示 信 息 


$titlecolor = $flag?'infotitle2':'infotitle3';// 标 题 颜 色 
$otherlink = $link == '' ?2"javascript:history.back();":$link;// 其 他 链接 
print <<<EOF 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"» 
<html xmlns-"http://www.w3.0rg/1999/xhtml"» 
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<head> 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
<title> 操 作 提 示 </title> 
<link href="img/main.css" rel="stylesheet" type="text/css" /> 
</head> 
<body> 
<div id="append parent"></div> 
"container" id="cpcontainer"><h3> 操 作 提示 </h3> 
infobox"><h4 class="$titlecolor">$message</h4><h5> 
«a class-"return btn" href="$otherlink" target="$target"> 返 回 </a> 
</h5></div> 
</div> 
</body> 
</html> 
EOF; 

exit(); 


} 
// 页 面 检测 


function html replace($str){ 


$str = stripslashes ($str);//4$MT 

$str = str replace('&','&amp; ',$str); 
$str = str replace ('\'','&#039;',$str); 
$str = str replace('"','&quot;',$str); 
$str = str replace('«','&lt;',$str); 
$str = str replace('»','&gt;',$str); 
$str = addslashes ($str); 


return $str; 


5 
// 判 断 
if(!function exists('json encode'))( 
require once (LIBDIR.'JSON.class.php');//i& A Xt ifi 
function json encode ($value) {// 编 码 对 象 
$json = new Services JSON(); 
return $json-»encode ($value); 
5 


Í 
// 判 断 
if(!function exists('json _decode'))1{// 判 断 存在 量 
require once (LIBDIR.'JSON.class.php');// 调 入 类 文件 
function json decode($json value,$bool = false)( 
$json = new Services JSON(); 
return $json-»decode ($json value, $bool); 


3.4.3 ”关于 页 面 处 理 的 基 类 


不 管 是 前 台 还 是 后 台 都 需要 对 页 面 基 本 处 理 ， 这 些 处 理 都 大 同 小 异 ， 可 以 说 其 他 的 页 
面 都 是 从 这 个 简单 的 代码 衍生 出 去 的 , 它 是 处 理 本 系统 的 基 类 ， 其 代码 (frontpage.php) 如 下 : 

<?php 

require once (LIBDIR.'view.class.php');// 调 入 显示 类 文件 


require once (INCDIR.'pagecore.php');// 调 入 页 面 
// 建 立 子 类 
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class frontpage extends pagecore{ 
function frontpage (){ 
global $setting;// 设 置 变量 
$this-»setting = S$setting;// 赋 值 
$this-»output -& get output () ;// 获 得 输出 量 
Sthis->view = new View(); 
$this-»db =& db(); 


$this-»output-»set('site title',$this-»setting['site title']); 
$this-»output-»set('site keyword',$this-»setting['site keyword']); 
$this-»output-»set('site description',$this-»setting 
['site description']); 
) 
) 


在 处 理 页 面 的 基 类 中 ， 还 有 一 段 也 是 十 分 的 
<?php 
// 建 立 类 


class pagecore( 


// 设 置 页 面 
function isPost (){ 
if (strtolower ($ SERVER['REQUEST METHOD']) == 'post'){ 
return true; 


下 要 ， 其 代码 (pagecore php) 如 下 : 


H 
return false; 


) 
// 获 取 数据 
function getGet ($key, $default-'')( 
if(isset($ GET[Skey]))( 
if(!get magic quotes gpc()) 
u 
if(is array($ GET[$key]1))( 
return array map('addslashes',$ GET[$key]); 
Jelse( 
return addslashes ($ GET[$key]); 
) 
) 
return $ GET[$key]; 


H 
return $default; 


) 
// 获 取 数据 
function getPost ($key, $default-'')( 
if(isset($ POST[$key]))( 
if(!get magic quotes gpc()) 
t 
if(is array($ POST[$keyl))( 
return array map('addslashes',$ POST[S$key]); 
Jelse( 
return addslashes ($ POST[$key]);// 添 加 和 斜 杠 
和 
下 
return $ POST[S$key] ;// 返 回 关键 字 
} 
return $default;// 获 得 缺 省 值 


} 
// 获 取 需 求 数据 


———————À—————————————Ó  '/Á'Á— » 
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function getRequest ($key, $default-' '){// 获 得 需求 
if (isset ($_REQUEST [$key] ) ){// 判 断 需求 
if(!get magic quotes gpc()) 
t 
if(is array($ REQUEST[S$key])) (t 
return array map('addslashes',$ REQUEST[$key]);// 排 列 图 
}else{ 
return addslashes ($ REQUEST [$key] ); 
} 
B 
return $ _ REQUEST[$key];// 返 回 请 求 
} return S$default; 
n 


3.4.4 ”相册 列表 


在 首页 中 ， 要 向 浏览 者 展示 不 同 的 相册 列表 ， 供 浏览 者 查看 ， 如 图 3-4 所 示 ， 下 面 将 通 
过 一 段 代 码 进行 讲解 。 


LU i | 
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图 3-4 相册 列表 
实现 这 个 相册 功能 十 分 简单 ， 下 面 通过 一 段 代 码 进行 讲解 ， 其 代码 如 下 : 


«?php 
class controller extends frontpage( 
function index () {// 建 立 一 个 引导 方法 
$this->mdl album = & load model('album'); 
$page = $this-»getGet ('page',0); 
if(!S$page)t 
$page = 1; 
H 
$albums = $this-»mdl album-»get all album($page,true); 


$pageurl-'index.php?ctl-album&page-[f4fpagef]'; 
if($albums['1s'])( 
foreach($albums['ls'] as $k-»$v)( 
$cover = $this-»mdl album-»get cover ($v['id'],$v['cover']) ; //&filii 
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$albums['1s'] [$k] ['cover'] = $cover?mkImgLink ($cover['dir'], 
$cover['pickey'],$cover['ext'], 'thumb'):'img/nopic.jpg' ; // $E Tii 
l 
$ 


$this-»output-»set('current nav','index');// 最 近 上 传 的 图 片 

$this-»output-»set ('albums', $albums['1s']);// 专 辑 
$this->output->set ('pageset',pageshow ($albums ['total'] ,$albums['start'], 
$pageur1) ) ;// 页 面 设置 

$this-»output-»set('total num',$albums['count']);// 总 量 


$site title = $this-»output-»get('site title').' - 相册 列表 '; 
$this-»output-»set('site title',$site title); 

// 显 示 
$this-»view-»display('front/album.php'); 


function newphotos (){// 最 新 图 片 
$page = $this-»getGet ('page',0);// 获 取 图 片 
// 判 断 
ifE(!$page){ 
$page = 1; 
) 
$pageurl-'index.php?act-newphotos&page- [fpaget] ' ; / / Y Ifi i i 

$mdl picture = & load model ('picture');//I] rig 

$piclist = $mdl picture-»get all pic($page,0,'time desc',0,true);// 
照片 列表 

$this-»output-»set ('piclist',$piclist['1s']); 
$this-»output-»set ('pageset',pageshow($piclist['total'], 
$piclist['start'],$pageurl));// 输 出 设置 

$this->output->set ('total num',$piclist['count']);// 合 计 

$this->output->set ('current nav','newphotos'); 

$this-»view-»display('front/newphotos.php'); 

} 


function hotphotos () {// 热 门 图 片 
$this-»output-»set('current nav','hotphotos');// 集 合 图 片 
$mdl picture = & load model('picture'); 
$piclist = $mdl picture-»get all pic(NULL,0, 'hot',10,true); 
$this-»output-»set('piclist',$piclist); 
$site title = $this-»output-»get('site title').' - 热门 图 片 '; 
$this-»output-»set('site title',$site title); 
$this-»view-»display('front/hotphotos.php'); 


3.44.5 图 片 的 处 理 
对 于 图 片 管理 系统 ， 图 片 显 示 的 美观 性 占据 了 十 分 重要 的 地 位 。 当 管理 人 员 发 现 将 要 


上 传 图 片 的 尺寸 不 确定 时 ， 为 了 保证 系统 运行 的 美观 ， 需 要 对 图 片 大 小 进行 修饰 处 理 。 如 
图 3-5 所 示 了 图 片 处 理 界面 。 
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图 3-5 图 片 处 理 界面 


下 面 通过 一 段 代 码 讲解 图 片 处 理 功能 ， 其 代码 (photophp) 如 下 : 


«?php 

// 设 置 一 个 图 片 控制 类 

class controller extends frontpage( 
function controller () {// 图 片 控制 方法 
parent: :frontpage () ;// 调 用 父 类 的 量 
$this-»mdl album = & load model('album'); 
$this-»mdl picture - & load model('picture'); 
$this-»output-»set('current nav','album'); 


} 


function resize() {// 图 片 大 小 
$size = $this-»getGet ('size','thumb');// 大 小 
$key = $this->getGet ('key'); // 关 键 字 


include once (LIBDIR. 'image.class.php');// 调 入 页 面 
$imgobj = new Image(); 
$pic = $this-»mdl picture-»get one pic by key ($key); 
if(!in array($size,array('small','square','medium','big', 'thumb')) 
II !$pic){ 
$imgobj->load (DATADIR. 'nopic.jpg');// 载 入 图 片 
$imgobj-»output (); 
exit; 
} 
$square = false; 
if ($size=="'small')1{// 小 图 片 
$width = '240'; 
$height = '240'; 
}elseif ($size=='thumb'){// 缩 略图 图 片 
$width = '110'; 
$height = '150'; 
Jelseif ($size=='square')1{// 正 方形 图 片 
$width = '75'; 
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$height UE 
$square - true; 
}elseif(S$size=='medium'){// 中 等 图 片 大 小 
$width = '550'; 
$height = '550'; 
Jelseif ($size=='big'){// 大 的 图 片 
$width = '900'; 
$height - '900'; 


} 
$orig = mkImgLink($pic['dir'],$key,$pic['ext'],'orig'); // 最 初 连接 
$resized = mkImgLink($pic['dir'],$key,$pic['ext'],$size); // 调 整 大 小 


if (file exists (ROOTDIR.$resized) ) {// 文 档 存在 
$imgobj->load (ROOTDIR.$resized) ;// 加 载 图 片 目标 文件 
$imgobj-»output () 7 
exit; 

} 


$imgobj->load (ROOTDIR. $0rig); 
$orgwidth = $imgobj->getWidth () ;// 获 取 宽 度 
$orgheight = $imgobj-»getHeight () ;// 获 取 高 度 
if(Sorgwidth <= $width && $orgheight <= $height)( 
copy (ROOTDIR.$orig, ROOTDIR.$resized); 
G& chmod (ROOTDIR.$resized,0755); 
$imgobj-»output () ; 
}else{ 
$imgobj->setQuality (95); 
if ($square) { 
$imgobj->square ($width) ;// 正 方形 图 片 
}else{ 
$imgobj->resizeScale ($width, $height) ;// 调 整 规模 
) 
$imgobj-»save (ROOTDIR.$resized); 


Gchmod (ROOTDIR. $resized, 0755);// 改 变 文件 
$imgobj-»output (); 


} 
// 设 置 图 片 浏览 


function view(){ 
$album = intval (Sthis->getGet ('album'));// 获 取 整 数值 
$picls = $this->mdl picture->get all pic (null, $album, 'time asc','0',true); 
$mini photo width = (count ($picls)+5)*65;// 迷 你 图 片 的 宽度 
$this-»output-»set('total imgs',count ($picls));// 总 数 
$this-»output-»set ('piclist',$picls);// 设 置 图片 列 表 
$this-»output-»set('mini photo width', $mini photo width) ;// 迷 你 图 片 宽度 
$this-»output-»set ('album name',$this-»mdl album-»get album name ($album)); 
$this-»output-»set ('album', $album); //A4Hi8 
$site title = $this-»output-»get('site title').' - 查看 图 片 '; 
$this-»output-»set('site title',$site title);// 设 置 站 点 标题 


$this->view->display('front/viewphoto.php');// 设 置 图 片 显示 
} 


function ajax addhit (){ 
$id = intval (Sthis->getGet('id'));// 获 取 id 号 
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$this-»mdl picture-»addHit ($id) ;// 添 加 成 功 


3.4.6 最 新 上 传 的 图 片 


在 前 台 展 示 的 功能 中 ， 最 新 上 传 的 图 片 是 按照 时 间 排 序 的 ， 将 最 近 上 传 的 图 片 排 到 最 
前 面 ， 然 后 将 数据 库 里 的 所 有 图 片 展示 给 浏览 者 ， 如 图 3-6 所 示 。 
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图 3-6 最 新 上 传 图 片 页 面 
下 面 通过 一 段 代码 进行 讲解 ， 其 代码 newphotos.php) 如 下 : 


<?php include('head.php');?>// 调 入 页 面 
«div class-"main boxl"» 
«div class-"bgl title"><h3> 最 新 上 传 的 图 片 </h3></div> 
«div class-"box body"» 
«table class-"tablel00"» 
«tr» 
<?php $1s = $res-»get('piclist'); 
ELS) 
foreach ($ls as $k-»$v): 
if($k != 0 && $k$5 == O)( 
echo '</tr><tr>'; 
} 
?» 
«td class-"phototd" id-"i «?php echo $v['id'];?»"» 
«a href-"index.php?ctl-photo&act-view&album- 
<?php echo $v['album']; ?»4photo-«?php echo $v['id'];?»"» 
«img src-"«?php echo mkImgLink($v['dir'], 
$v['pickey'],$v['ext'],'thumb');?»" /»«/a» 
«div class-"line35"» 

«a href-"index.php?ctl-photo&act-view&album- 
<?php echo $v['album']; ?»4photo-«?php echo $v['id'];?»"» 
<?php echo $v['name'];?»«/a» 

«/div» 
<div> 浏 览 数 : «?php echo $v['hits'];?»«/div» 
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«/td» 
«?php 
endforeach; 
else: 
?> 
«td»«div class="warning"> 当前 没有 任何 图 片 ! </div></td> 
«?php 
endif; 
2 
«/tr» 
</table> 
«div class="pageset"><?php echo $res-»get ('pageset');?»«/div» 
«/div» 
«/div» 


<?php include ('foot.php');2?>// 调 入 底部 文件 


3.4.7 ”最 热门 的 图 片 


最 热门 的 图 片 是 按照 图 片 单 击 的 次 数 排列 ， 单 击 率 高 的 排 在 最 前 面 ， 单 击 率 低 的 排 在 
后 面 ， 如 图 3-7 所 示 。 
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图 3-7 最 热门 图 片 页 面 
下 面 通过 一 段 代码 进行 讲解 ， 其 代码 (hotphotos.php) 如 下 : 


<?php include ('head.php') ;2?>// 调 入 头 部 文件 
«div class-"main box1"> 
«div class-"bgl title"><h3> 热 门 图 片 </h3></div> 
«div class-"box body"> 
«table class-"tablel00"» 
«tr» 
«td»«/td» 
«td»«/td» 
«td»«/td» 
«td»«/td» 
«td»«/td» 
«/tr» 


< 
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«tr» 
<?php $ls = $res-»get('piclist'); 
mS NUS 
foreach ($ls as $k-»$v): 
if($k !— 0 && $k$5 == O)( 
echo '«/tr»«tr»'; 
H 
m 
<td class-"phototd" id-"i <?php echo $v['id'];?»"» 
«a href-"index.php?ctl-photo&act-view&album- 
<?php echo $v['album']; ?»4photo-«?php echo $v['id'];?»"»«img src=" 
<?php echo mkImgLink($v['dir'],$v['pickey'],$v['ext'], 'thumb');?»" /»«/a» 
«div class-"line35"» 

«a href-"index.php?ctl-photo&act-view&album- 
<?php echo $v['album']; ?»4photo-«?php echo $v['id'];?»"» 
<?php echo $v['name'];?»«/a» 

«/div» 
<div> 浏 览 数 : <?php echo $v['hits'];?»«/div» 
«/td» 
«?php 
endforeach; 
uec ?» 
«td»«div class-"warning"» 当前 没有 任何 图 片 ! </div></td> 
<?php 
endif; 
?» 
«/tr» 
</table> 
</div> 
</div> 
<?php include('foot.php');?» 


在 使 用 相册 的 时 候 ， 没 有 感觉 到 如 此 麻烦 ， 当 设计 到 前 台 的 时 候 ， 感 觉 到 每 一 个 功能 、 
每 一 行 代码 、 每 一 个 功能 的 实现 都 需要 程序 设计 者 呕心沥血 。 尤 其 处 理 好 功能 模块 是 开发 
相册 的 难点 之 一 ， 理 清 结构 也 十 分 重要 ， 虽 然 他 们 都 在 不 同 程度 地 处 理 数据 库 内 容 ， 但 是 
每 一 个 炫 的 功能 都 必须 与 使 用 习惯 联系 起 来 ， 只 有 这 样 ， 系 统 才 会 真正 易 用 。 


3.5 后 台 设 计 


[3003 29 20, d. 66a 

经 过 过 去 三 天 的 忙碌 ， 我 的 前 台 模块 的 设计 工作 和 编码 工作 都 顺利 完成 了 。 在 我 进行 
前 台 设计 工作 的 同时 ， 后 台阶 段 的 设计 和 编码 工作 也 开始 了 。 此 阶段 工作 由 同事 C 来 完成 
他 根据 前 期 规划 和 数据 库 设计 ， 很 快 在 脑海 中 形成 了 一 个 大 体 的 设计 流程。 


3.5.1 后 台 首 页 


后 台 首 页 是 用 户 登 录 的 窗口 ， 如 图 3-8 所 示 ， 用户 输入 合法 的 用 户 名 和 密码 后 ,就 可 以 
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进入 后 台 ， 对 整个 系统 进行 管理 。 
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下 面 通过 几 段 代码 进行 讲解 ， 第 一 段 代码 为 后 台 首 页 ， 主 要 是 调用 代码 的 页 面 ， 代 码 
(admin.php) 如 下 : 
<?php 


header ("Content-type: text/html; charset=utf-8");// 设 置 页 面 基 本 信息 
define('Version','1.1');// 设 置 系统 版 本 号 
define('FCPATH', FILE  ) ; /设置 文件 类 型 
define('ROOTDIR',dirname(FCPATH).'/'); 
require once ('conf/setting.php');//W PUT 
require once('conf/config.php');// 配 置 
define('COREDIR',ROOTDIR. 'core/'); 
define('LIBDIR',COREDIR.'libs/'); 
define('INCDIR',COREDIR.'include/'); 
define('CTLDIR',COREDIR.'ctls/'); 
define('VIEWDIR',COREDIR. 'views/'); 
define('MODELDIR',COREDIR. 'models/'); 


define('DATADIR',ROOTDIR. 'data/'); 

// 如 果 防 盗 链 或 者 按 需 生成 图 片 失效 的 话 ， 请 打开 此 项 并 填写 合适 的 路 径 
//define('REWRITE BASE','/'); 

define('SITE URL',$setting['url']); 

define('PAGE SET',$setting['pageset']); 

require once(INCDIR.'base.php'); 

require once(INCDIR.'func.php'); 

run admin(); 


它 的 功能 很 简单 ， 它 并 不 能 完成 登录 ， 它 只 能 对 后 台 的 全 局 管理 ， 调 用 相应 的 页 面 ， 
后 台 真 正 的 登录 页 面 是 另 一 个 页 面 ， 其 代码 dogin php) 如 下 : 


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http: //www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"» 
<html xmlns-"http://www.w3.0rg/1999/xhtml"» 
«head» 
«meta http-equiv-"Content-Type" content-"text/html; charset-utf-8" /» 
<title> 西 南 传媒 大 学 影视 学 院 活动 中 心 </title> 


<meta name="description" content="" /> 
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«meta name-"keywords" content-"" /> 
<link rel="stylesheet" href-"img/login.css" type="text/css" /> 
<script language="javascript"> 
// 处 理事 件 
function fEvent (sType, oInput) {// 处 理事 件 
switch (sType)t 
case “focus” : 
oInput.isfocus = true;// 焦 点 
oInput .style.backgroundColor='#FFFFD8';// 背 景 颜色 
case "mouseover" : 
oInput.style.borderColor = '#298CBA' ;边框 颜色 
break; 
case "blur" : 
oInput.isfocus - false; 
oInput.style.backgroundColor-""; 
case "mouseout" : 
if(!oInput.isfocus)( 
oInput.style.borderColor-'4CDDFE4'; 


) 
break; 
} 
} 
</script> 
</head> 
<body> 
<div class="login"> 
<div class="login center"> 
<div id="messages"> 
<?php switch ($res->get ('flag')){ 
case vule 
echo “用 户 名 密码 错误 ! '; 
break; 
(eise Um 
echo ' 您 已 成 功 退 出 ! '; 
break; 
default: 
echo ' 您 好 ， 欢 迎 登录 ! '; 


)?» 


<br/> 
«/div» 


«div id-"logo"» 
«/div» 
«form method-"post" target-" top" 
action-"admin.php?ctl-default&act-login" name-"login soft"» 
«p class="label"> 账 号 : «br /»«input type="text" 
class-"login input" name-"loginname" 
onMouseOver-"fEvent ('mouseover',this)" onFocus-"fEvent('focus',this)" 
onBlur-"fEvent ('blur',this)" onMouseOut-"fEvent ('mouseout',this)"»«/p» 
«p class-"label"24*; fij: «br /»«input type="password" class-"login input" 
name-"operatorpw" onMouseOver-"fEvent ('mouseover',this)" 
onFocus-"fEvent('focus',this)" onBlur-"fEvent ('blur',this)" 
onMouseOut-"fEvent ('mouseout',this)"»«/p» 
Xp class-"label"» «input type="checkbox" name-"remember" 
value-"1" /> 记 住 密码 
<input type-"submit" class-"login botton" name-"submit" value=" 登 录 "></p> 
</form> 
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<script type-"text/javascript"» 
window.document.login soft.loginname.focus(); 
</script> 

</div> 


«div id="footlink"><a href="index.php">&lt;&lt; 返回 首页 </a></div> 
</div> 


</body> 
</html> 


3.5.2 登录 相册 的 首页 


当 用 户 登 录 后 台 后 ， 将 会 进入 一 个 全 新 的 页 面 ， 这 个 页 面 将 提供 后 台 操作 功能 的 超 链 
接 ， 供 用 户 使 用 ， 如 图 3-9 所 示 。 
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图 3-9 后 台 首页 
下 面 通过 一 段 代 码 进行 讲解 ， 其 代码 如 下 : 


<?php include ('head.php');?>// 调 入 头 部 文件 
<div id="allpic"> 

«div id-"album nav"» «span class-"total count"»JL «strong» 
<?php echo $res-»get('total num');?»«/strong» 张 图 片 </span> 
«input type-"button" 
class="btn" value=" 我 要 上 传 图 片 ” onclick- 
"window.location.href-'admin.php?ctl-upload'" /»«/div» 

«form name-"pics form" action= 
"admin.php?ctl-photo&act-bat&referf-default&referp-«?php echo 
$res-»get('page');?»" method="post" onsubmit 
-"submit bat(this);return false;"» 

«div id-"batch ctrl"» 

«input type-"button" class-"btn" value=" 全 选 " onclick- 
"checkall('pics form')" /> 

«input type-"button" class-"btn" value=" 取 消 全 选 " onclick- 
"uncheckall('pics form')" /> 

«select name-"do action"» 
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«option value="-1"> 批 量 操作 </option> 

<option value="delete"> 选 中 图 片 彻底 删除 </option> 

<option value="move"> 选 中 图 片 移动 到 </option> 
</select> 
<select name="albums" style="display:none"> 

<option value="-1"> 选 择 相 册 </option> 
<?php 

$ls = $res-»get('albums list'); 

if ($1s){ 

foreach ($1s as $k-»$v)( 
echo "<option value=\"".$k."\">".$v."</option>\n"; 


} 
} 
?» 
«/select» 
<input name-"do pic act" type="submit" 
value=" 执 行 " class="btn" disabled /> 
<select name="do sort" onchange="change order (this.value);"> 
<option value="-1"> 选 择 排序 </option> 
<option value-"admin.php?act-all&sort-time desc&page- 
<?php echo $res-»get('page');?»" <?php if 
($res-»get('sort')--'time desc') 
( echo 'selected-"selected"';] ?>> 按 照 时 间 从 近 到 远 排序 </option> 
<option value-"admin.php?act-all&sort-time asc&page- 
<?php echo $res-»get ('page');?»" 
<?php if($res-»get('sort')--'time asc') 
( echo 'selected-"selected"';] ?>> 按 照 时 间 从 远 到 近 排 序 </option> 
</select> 
«input type="button" value=" 约 灯 片 查 看 ” class-"btn" 
onclick-"slideshow(0)" /> 
«/div» 
<?php if($res-»get('msginfo'))( echo $res-»get('msginfo');)?» 
«ul class-"album"» 


«?php 

$1s = $res-»get('pics'); 
if(S$1s): 

foreach($1s as $v): 

?» 


«li id-"i «?php echo $v['id'];?»" rel-" 
<?php echo SITE URL.mkImgLink($v['dir'] 
,$v['pickey'],$v['ext'], 'orig');?»"» 
«span class-"img"» 
«a href-"admin.php?ctl-photo&act-view&id- 
<?php echo $v['id'];?»"»«img src= 
"<?php echo mkImgLink($v['dir'],$v['pickey'],$v['ext'], 'thumb') ; ?»" 
alt-"«?php echo $v['name'];?»" /»«/a» 
</span> 
<span class="info"><a onclick-"rename pic (this, 
<?php echo $v['id'];?>)"><?php echo $v['name'];?»«/a»«/span» 
<span class-"control"» 
«a href-"javascript:void(0)" onclick-"copyUrl (this)"» 
«img src-"img/copyu.gif" alt=" 复 制 网 址 "title=" 复 制 网 址 ” /»«/a» 
«a href-"javascript:void(0)" onclick-"copyCode (this)"> 
«img src-"img/copyc.gif" alt=" 复 制 代码 ”title=" 复 制 代码 " /»«/a» 
«a href-"javascript:void(0)" onclick-"delete pic(this, 
<?php echo $v['id'];?»)"» 
«img src-"img/delete.gif" alt=" 删 除 "title=" 删 除 "” /»«/a» 
«a href-"javascript:void(0)" onclick-"reupload pic (this, 
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<?php echo $v['id'];?»)"»«img src-"img/re upload.gif" alt=" 重 新 上 传 " title= 
"重新 上 传 此 图 片 " /></a> 
«a href-"javascript:void(0)" onclick-"move pic to(l,this, 
<?php echo $v['id'];?»)"»«img src-"img/moveto.gif" alt=" 移 动 到 相册 " 
title=" 移 动 到 相册 " /»«/a» 
</span> 
<div class="cb"><input type="checkbox" name="picture[]" value= 
"<?php echo $v['id'];?»" onclick-"select pic(this,«?php echo $v['id'];?»)" 
/»«/div» 
«div class-"selected"»«/div» 
</li> 
<?php 
endforeach; // 最 后 一 个 记录 
So 
echo "<1i> 无 图 片 </1i>"; 
endif; 
?> 
</ul> 
</form> 
«div class="pageset"><?php echo $res->get ('pageset');?></div> 
</div> 
<script type="text/javascript"> 
init submit bat(); 
</script> 
<?php include ('foot.php') ;2?>// 调 入 底部 文件 


3.5.8 创建 相册 


创建 相册 是 用 户 后 台 为 了 更 好 地 管理 相册 的 内 容 而 操作 的 功能 ， 当 后 台 的 照片 越 来 越 
多 的 时 候 ， 用 户 就 需要 对 照片 进行 分 类 ， 如 图 3-10 所 示 。 
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3-10 ”创建 相册 
创建 相册 的 功能 十 分 简单 ， 下 面 通 过 一 段 代码 进行 讲解 ， 其 代码 (album.php) 如 下 : 
<?php include ("'head.php');2>// 调 入 头 部 文件 


«div id-"allpic"» 
<div id-"album nav"» «span class-"total count"> 共 <strong> 
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<?php echo $res-»get('total num');?»«/strong» 个 相册 </span> 
«input type-"button" onclick-"create album(1)" value=" 创 建 相册 " 
class="btn"></div> 
<ul class="album"> 
<?php 
$ls = $res-»get('albums'); 
if($1s): 
foreach ($ls as $v): 
?> 
<li> 
<?php if($v['private'])( ?> 
<div class-"priv" title=" 私 有 相册 "></div><?php ) ?> 
<span class="img"> 
«a href-"admin.php?ctl-album&act-photos&album-«?php echo $v['id']; ?>"> 
«img src-"«?php echo $v['cover'];?»" alt-"«?php echo $v['name'];?»" /»«/a» 
</span> 
<span class-"info"»«a onclick-"rename albun (this, 
<?php echo $v['id'];?>)"><?php echo $v['name'];?»«/a»«/span» 
«span class-"control"» 
<a href-"javascript:void(0)" onclick-"delete album(this, 
<?php echo $v['id'];?»)"» 
«img src-"img/delete.gif" alt=" 删 除 相 册 "” tit1le=" 删 除 相 册 "” /></a> 
«a href-"javascript:void(0)" onclick-"edit priv album(this, 
<?php echo $v['id'];?»)"»«img src-"img/lock.gif" alt=" 修 改 权限 "title=" 修 改 
权限 " /»«/a»«/span» 
«/1i» 
«?php 
endforeach; 
endif; 
?> 
</ul> 
«div class="pageset"><?php echo $res-»get ('pageset');?»«/div» 
«/div» 
<?php include('foot.php');?>// 调 入 底部 文件 


3.5.4 ”编辑 相册 


用 户 可 以 根据 自己 的 需要 删除 相册 、 设 置 相 册封 面 、 移 动 相册 照 片 等 操作 ， 下 面 通过 
一 段 代码 进行 讲解 ， 其 代码 (album photos.php) 如 下 : 


<?php include ('head.php');?>// 调 入 头 部 文件 
«div id-"allpic"» 
«div id-"album nav" class-"album detail"» 
<hl class-"album title"»«?php echo $res-»get('album name');?»«/hl» 
«span class-"total count"> 共 <strong> 
«?php echo $res-»get('total num');?></strong> 张 图 片 </span> 
«input type="button" class="btn" value=" 上 传 图 片 " onclick- 
"window.location.href-'admin.php?ctl-upload&act-step2&album id= 
<?php echo $res-»get('album');?»'" /> 
</div> 
«form name-"pics form" action-"admin.php?ctl-photo&act-bat&album 
—«?php echo $res-»get ('album');?»&referf-album&referp 
=<?php echo $res-»get ('page') ;?»" method="post" onsubmit-"submit bat (this); 
return false;"» 
«div id-"batch ctrl"» 
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«input type-"button" class-"btn" value=" 全 选 " 
onclick-"checkall('pics form')" /> 
«input type-"button" class-"btn" value=" 取 消 全 选 " 
onclick-"uncheckall('pics form')" /> 
<select name-"do action"» 
«option value="-1"> 批 量 操作 </option> 
<option value="delete"> 选 中 图 片 彻底 删除 </option> 
<option value="move"> 选 中 图 片 移动 到 </option> 
</select> 
<select name="albums" style="display:none"> 
<option value="-1"> 选 择 相册 </option> 
«?php 
$ls = $res-»get('albums list'); 
if(S$1s)t 
foreach ($ls as $k-»$v)( 
echo "<option value-WV"".$k."V"»".$v."«/option»An"; 


) 
} 
?» 
«/select» 
«input name-"do pic act" type-"submit" value=" 执 行 " 
class-"btn" disabled /» 
<select name-"do sort" onchange-"change order (this.value);"» 
«option value="-1"> 选 择 排序 </option> 
<option value-"admin.php?ctl-album&act-photos&album- 
<?php echo $res-»get('album');?»&sort-time desc&page- 
<?php echo $res-»get('page');?»" <?php if($res-»get('sort') 
--'time desc') 
( echo 'selected-"selected"';) ?>> 按 照 时 间 从 近 到 远 排序 </option> 
«option value-"admin.php?ctl-album&act-photos&album 
-«?php echo $res-»get('album');?»&sort-time asc&page 
?php echo $res-»get('page');?»" <?php if($res-»get('sort') 
--'time asc')( echo 'selected-"selected"';) ?> 
> 按照 时 间 从 远 到 近 排 序 </option> 
</select> 
<input type="button" value=" 幻 灯 片 查看 ”class="btn" onclick 
-"slideshow(«?php echo $res-»get('album');?»)" /> 
«/div» 
<?php if($res-»get('msginfo'))( echo $res-»get ('msginfo');)?» 
<ul class-"album"» 


«?php 

$1s = $res-»get('pics'); 
if($1s): 

foreach ($ls as $v): 

?» 


«li id-"i <?php echo $v['id'];?»" rel 
-"«?php echo SITE URL.mkImgLink ($v['dir'],$v['pickey'],$v['ext'], 'orig') ;?»"» 
<span class-"img"» 
«a href-"admin.php?ctl-photo&act-view&id 
=<?php echo $v['id'];?»&album- 
<?php echo $res-»get ('album');?»"» 

«img src-"«?php echo mkImgLink ($v['dir'],$v['pickey'],$v['ext'], 'thumb') ; 
?»" source-"«?php echo mkImgLink ($v['dir'],$v['pickey'],$v['ext'], 'orig');?»" 
alt-"«?php echo $v['name'];?»" /> 

</a> 
</span> <span class="info"> 
«a onclick-"rename pic (this, 
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<?php echo $v['id'];?»)"»«?php echo $v['name'];?></a> 
«/span» 
<span class-"control"» 
«a href-"javascript:void(0)" onclick-"copyUrl (this)"» 
«img src-"img/copyu.gif" alt=" 复 制 网 址 ”title=" 复 制 网 址 ” /»«/a» 
«a href-"javascript:void(0)" onclick-"copyCode (this)"> 
«img src-"img/copyc.gif" alt=" APR" title=" APRE" /»«/a» 
<a href-"javascript:void(0)" onclick-"delete pic (this, 
<?php echo $v['id'];?>)"> 
«img src-"img/delete.gif" alt=" 删 除 "” title=" 删 除 ” /></a> 
«a href-"javascript:void(0)" onclick-"reupload pic (this, 
<?php echo $v['id'];?»)"»«img src-"img/re upload.gif" alt=" 重 新 上 传 " title=" 
重新 上 传 此 图 片 "” /> 
«/a» 
«a href-"javascript:void(0)" onclick-"set pic cover (this, 
<?php echo $v['id'];?»)"» 
«img src-"img/cover.gif" alt=" 设 为 封面 "title=" 设 为 封面 " /»«/a» 
<a href-"javascript:void(0)" onclick-"move pic to(2,this, 
<?php echo $v['id'];?»)"» 
«img src-"img/moveto.gif" alt=" 移 动 到 相册 "tit1le=" 移 动 到 相册 " /> 
</a> 
</span> 
<div class="cb"> 
<input type="checkbox" name="picture[]" value="<?php echo $v['id'];?>" 
onclick="select pic(this,«?php echo $v['id'];?>)" /></div> 
<div class="selected"></div> 
«/1i» 
«?php 
endforeach; 
elses 
echo "<1i> 无 图 片 </1i>"; 
endif; 
?» 
«/ul» 
«/form» 
«div class-"pageset"» 
<?php echo $res-»get('pageset');?» 
«/div» 
«/div» 
«script type-"text/javascript"» 
init submit bat(); 
«/script» 
<?php include('foot.php');?» 
// 调 入 底部 文件 


3.5.5 ”设置 相册 

用 户 可 以 根据 自己 的 喜好 设置 相册 ， 设 置 相册 分 为 常规 设置 、 管 理 员 设置 、 修 改 密码 
和 后 台 任务 等 重要 功能 。 

1 常规 设置 

常规 设置 里 用 户 可 以 根据 自己 的 喜好 定义 站 点 名 称 、 站 点 关键 字 、 上 传 设置 、 首 页 显 
示 设 置 等 最 基本 的 信息 ， 如 图 3-11 所 示 。 
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图 3-11 常规 设置 
下 面 通过 一 段 代码 进行 讲解 ， 其 代码 (setting.php) 如 下 : 


<?php include ('head.php');?>// 调 入 头 部 文件 
<?php $setting = $res-»get('setting');?» 
«div id-"setting box"» 
«div id-"setting nav"» 
<?php include('setting nav.php'); ?>// 导 航 配置 文件 
«/div» 
«div id-"setting body"» 
«form method="post" action-"admin.php?ctl-setting"» 
«div id-"base setting" class-"stab"» 
«hl class-"album titlel"> 基 本 设置 </h1> 
<table> 
<tbody> 
<tr> 
«td class="tt"> 站 点 名 称 : </td><td class="tc"> 
«input name-"setting[site title]" class-"txtinput" type-"text" value 
-"«?php echo $setting['site title'];?»" style-"width:250px" /»«/td»«td 
class="ti"> 前 台 显示 的 TITLE«/td» 
«/tr» 
«tr» 
«td class="tt"> 站 点 关键 字 : «/td»«td class-"tc"» 
«input name-"setting[site keyword]" class-"txtinput" type-"text" 
value-"«?php echo $setting['site keyword'];?»" 
style-"width:250px" /»«/td»«td class-"ti"» 
前 台 META KEYWORD， 关 键 字 使 用 空格 或 , 分 割 </td> 
«/tr» 
«tr» 
«td class="tt"> 站 点 描述 : «/td»«td class-"tc"» 
<input name="setting[site description]" class="txtinput" type="text" 
value-"«?php echo $setting['site description'];?»" style-"width:250px" /> 
«/td»«td class="tin> 前 台 META DESCRIPTION</td> 
«/tr» 
«tr» 
«td class="tt"> 相 册 URL: «/td»«td class-"tc"» 
«input name-"setting[url]" class-"txtinput" type-"text" value- 
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"<?php echo $setting['url'];?»" style-"width:250px" /»«/td»«td class="ti"> 
设置 复制 图 片 地 址 的 URL 前 级 ， 需 要 带 上 末尾 的 "/"</tqd> 
ctn» 
«tr» 
«td class="tt"> 按 需 生 成 各 种 尺寸 图 片 : «/td» 
«td class-"tc"» 
<input name-"setting[demand resize]" type="checkbox" 
value-"1" <?php if($setting['demand resize']) 
{ echo 'checked-"checked"';] ?> /> 
«/td» 
«td class="ti"> 开 启 此 项 需要 支持 Rewrite, 关闭 此 项 则 会 在 上 传 时 生成 各 种 
尺寸 图 片 </tq> 
</tr> 
</tbody> 
</table> 
</div> 
<div id="upload setting" class="stab"> 
<hl class-"album titlel"> 上 传 设置 </h1> 
<table> 
<tbody> 
<tr> 
«td class="tt"> 是 否 开启 客户 端 预 处 理 : «/td»«td class="tc"><input 
id="setting open pre resize" name= 
"setting[open pre resize]" type-"checkbox" value="1" 
<?php if($setting['open pre resize']) 
( echo 'checked-"checked"';]) ?> 
onclick-"switch div(this,'imgsetting div');" /» 
«/td»«td class-"ti"» 
在 客户 端 预 处 理 可 以 大 大 减少 网 络 传输 ， 缩 短 上 传 时间 。 开 启 后 无 法 获取 照片 EXIF 信息 </td> 
«/tr» 
</tbody> 
<tbody id="imgsetting div"> 
<tr> 
«td class="tt"> 图 片 宽 : «/td»«td class-"tc"» 
<input name="setting[resize img width]" class="txtinput" type="text" value= 
"<?php echo $setting['resize img width'];?>" style-"width:50px" /> 
«/td»«td class="ti"> 客 户 端 预 处 理 图 片 的 最 大 宽度 </td> 
</tr> 
<tr> 
«td class="tt"> 图 片 高 : «/td»«td class="tc"><input name= 
"setting[resize img height]" class-"txtinput" type-"text" value- 
"<?php echo $setting['resize img height'];?»" style-"width:50px" /> 
«/td»«td class="ti"> 客 户 端 预 处 理 图 片 的 最 大 高 度 </td> 
«/tr» 
«tr» «td class="tt"> 图 片 质量 : «/td»«td class-"tc"» 
«input name-"setting[resize quality]" class-"txtinput" type-"text" value- 
"<?php echo $setting['resize quality'];?»" style-"width:50px" /> 
«/td»«td class="ti"> 预 处 理 图 片 的 质量 1-100«/td» 
«/tr» 
«/tbody» 
«script» 
if(S$('f£setting open pre resize').get(0).checked)( 
$("£imgsetting div").show(); 
Jelse( 
$("£imgsetting div").hide(); 
H 
</script> 
<tbody> 
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<tr> 
«td class-"tt"» EftT HREN: «/td»«td class-"tc"» 
«select name-"setting[imgdir type]"» 
<option value-"1" <?php if($setting['imgdir type']--'1') 
echo 'selected-"selected"';?»»YYYYMMDD«/option» 
<option value-"2" <?php if($setting['imgdir type']--'2') 
echo 'selected-"selected"';?»»YYYYMM«/option» 
«/select»«/td»«td class="ti"> 如 : data/20100520/xxxx.jpg«/td» 
</tr> 
«td class="tt"> 普 通 上 传 允许 的 图 片 大 小 : </td><td class="tc"> 
<input name="setting[size allow]" class="txtinput" type="text" value=" 
«?php echo $setting['size allow'];?>" style-"width:80px" /> 
«/td»«td class="ti"> 单 位 : 字 节 </td> 
</tr> 
</tbody> 
</table> 
</div> 
<div id="display setting" class="stab"> 
«hl class-"album titlel"> 显 示 设 置 </h1> 
«table» 
«tbody» 
«tr» 

«td class="tt"> 每 页 显示 图 片 数 : «/td»«td class-"tc"»«input 
name-"setting[pageset]" class="txtinput" type-"text" value-"«?php echo 
$setting['pageset'];?»" style-"width:50px" /»«/td»«td class-"ti"» 
«/td» 


«/tr» 
«tr» 
«td class="tt"> 约 灯 片 图 片 显示 限 制 : «/td»«td class-"tc"»«input 
name-"setting[gallery limit]" class-"txtinput" type-"text" value-" 
<?php echo $setting['gallery limit'];?»" style-"width:50px" /»«/td»«td 
class-"ti"»«/td» 
«/tr» 
«/tbody» 
</table> 
</div> 
<div id="display_setting" class="stab"> 
«hl class-"album titlel"> 图 片 设置 </h1> 
<table> 
<tbody> 
«tr» 
«td class="tt"> 使 用 水 印 : «/td»«td class-"tc"» 
<input id="setting open watermark" name="setting[open watermark]" type= 
"checkbox" value-"1" «?php if($setting['open watermark']) 
{ echo 'checked-"checked"';) ?> onclick-"switch div(this,'watermark div');" 
/»«/td»«td class-"ti"»«/td» 
«/tr» 
</tbody> 
<tbody id="watermark div"> 
«tr» 
«td class="tt"> 水 印 图 片 路 径 : 
«/td»«td class="tc"> 
<input name="setting[watermark path]" class="txtinput" type="text" value= 
"<?php echo $setting['watermark path'];?>" style-"width:250px" /»«/td»«td 
class="ti"> 如 data/water.png， 水 印 图 片 只 支持 png, gif,jpg«/td» 
«td class="tt"> 水 印 位 置 : «/td»«td class="tc"> 
<table> 
<td> 
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«input type="radio" name-"setting[watermark pos]" value-"1" 

<?php if($setting['watermark pos']--1)( echo 'checked-"checked"';] ?> /> 
d1«/td»«td»«input type="radio" name-"setting[watermark pos]" value-"2" 
<?php if($setting['watermark pos'] ){ echo 'checked-"checked"';) ?> /> 
d$2«/td»«td»«input type="radio" name-"setting[watermark pos]" value-"3" 
«?php if(Ssetting['watermark pos']--3)( echo 'checked-"checked"';]) ?> /> 
#3</td> 


</tr> 

<tr> <td> 
<input type="radio" name="setting[watermark pos]" value="4" 
<?php if($setting['watermark pos']==4){ echo 'checked="checked"';} ?> /> 
#4</td><td><input type="radio" name="setting[watermark pos]" value="5" 
<?php if($setting['watermark pos'] ){ echo 'checked-"checked"';] ?> /> 
d$5«/td»«td»«input type="radio" name-"setting[watermark pos]" value-"6" 
«?php if($setting['watermark pos'] 6)( echo 'checked-"checked"';) ?> /> 
#6</td> 


</tr> 
<tr> 
<td><input type-"radio" name-"setting[watermark pos]" 
value-"7" <?php if($setting['watermark pos']--7)( echo 'checked- 
"checked"';] ?> /> 
#7</td><td><input type-"radio" nam 


"setting[watermark pos]" value-"8" 
«?php if($setting['watermark pos'] 8)( echo 'checked-"checked"';) ?> /> 
$8«/td»«td»«input type="radio" name-"setting[watermark pos]" value-"9" 
<?php if($setting['watermark pos']--9)( echo 'checked-"checked"';] ?> /> 
#9</td> 


«/tr» 
«tr» 
«td colspan-"3"»«input type-"radio" name-"setting[watermark pos]" 
value-"0" <?php if($setting['watermark pos']--0)( echo 'checked- 
"Checked"';) ?> /> 随机 </td> 


«/table» 
«/td»«td class-"ti"»«/td» 
«/tbody» 
«/table» 
«/div» 
«script» 


if ($('#setting open watermark').get(0).checked)( 
$("£watermark div").show(); 
Jelse( 
$("£watermark div").hide(); 
5 
</script> 
<div id="priv setting" class="stab"> 
«hl class-"album titlel"> 权 限 设置 </h1> 
<table> 
<tbody> 
<tr> 
«td class="tt"> 开 放 相 册 : «/td»«td class="tc"> 
<input id="setting open photo" name="setting[open photo]" type="checkbox" 
value-"1" <?php if($setting['open photo']){ echo 'checked="checked"';} ?> 
/»«/td»«td class-"ti"»«/td» 
«td class="tt"> 开 启 防盗 链 : «/td»«td class-"tc"» 
«input id-"setting access ctl" name-"setting[access ctl]" type-"checkbox" 
value-"1" <?php if($setting['access ctl'])( echo 'checked-"checked"';] ?> 
/»«/td»«td class-"ti"»«/td» 
«/tr» 
«tr» 


«td class="tt"> 人 允许 的 域名 列表 : «/td»«td class-"tc"» 
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<textarea name-"setting[access domain]" 
style-"margin-left: 4px; width:300px; 
height: 100px;"»«?php echo $setting['access domain'];?» 
«/textarea»«/td»«td 
class="ti"> 一 行 一 条 域名 ， 请 勿 带 上 前 面 的 http://</td> 
<td></td><td><input type="submit" class="btn" value= 
"保存 设置 " /»«/td»«td»«/td» 

<?php include('foot.php');?>// 底 部 文件 


2. 管理 员 设 置 
当 系 统 随 着 用 户 的 增加 ， 一 个 管理 员 可 能 是 无 法 完成 整个 相册 的 管理 ， 通 常 需 要 多 个 
管理 员 对 管理 进行 设置 ， 如 图 3-12 所 示 。 
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图 3-12 ”管理 员 设置 
下 面 通过 一 段 代码 进行 讲解 ， 其 代码 (setting_operator add.php) 如 下 : 


<?php include('head.php');?>// 调 入 头 部 文件 
<div id="setting box"> 
<div id="setting nav"> 
«?php include('setting nav.php'); ?>// 调 入 导航 文件 
</div> 
<div id="setting body"> 
<div id="operator setting" class="stab"> 
«hl class-"album titlel"> 添 加 管理 员 </h1> 
«form method-"post" action= 
"admin.php?ctl-setting&act-operator add"» 
«table» 
«tr»«td class="tt"> 登 录 名 </td><td><input type-"text" 
name="username" class="txtinput" /></td></tr> 
«tr»«td class="tt"> 密 码 </td><td><input type-"password" 
name="userpass" class="txtinput" /></td></tr> 
<tr><td class="tt"> 重 复 密码 </td><td><input type="password" 
name-"passagain" class-"txtinput" /»«/td»«/tr» 
«tr» 
«td»«/td» 
<td><input type="submit" class="btn" value=" 确 定 添加 " 
/»«/td» 
«/tr» 
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«/table» 
«/form» 
«/div» 
</div> 
</div> 
<?php include ('foot.php');2?>// 调 入 头 部 文件 


3. 修改 管理 员 密码 


管理 员 密码 就 像 钥匙 一 样 ， 随 着 时 间 的 流逝 ， 可 能 会 有 泄露 ， 用 户 时 常会 根据 需要 随 


时 修改 密码 ， 如 图 3-13 所 示 。 
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下 面 通过 一 段 代码 进行 讲解 ， 其 代码 如 下 : 
<?php include ('head.php') ;?>// 调 查 头 部 文件 
«?php $info = $res-»get('operator'); ?>// 信 息 
«div id-"setting box"» 
«div id-"setting nav"» 
<?php include('setting nav.php'); ?>// 调 入 导航 文件 
</div> 
<div id="setting body"> 
<div id="operator setting" class="stab"> 
«hl class-"album titlel"> 修 改 管理 员 密码 </h1> 
<form method="post" action= 
"admin.php?ctl-setting&act-operator edit"> 
<input type="hidden" name="id" value=" 
«?php echo $info['id'];?»" /> 
«table» 
<tr><td class="tt"> 登 录 名 </td><td> 
<?php echo $info['username'];?></td></tr> 
<tr><td class="tt"> 密 码 </td><td> 


«input type="password" name-"userpass" class-"txtinput" /»«/td»«/tr» 


<tr><td class="tt"> 重 复 密码 </td><td> 


«input type-"password" name-"passagain" class-"txtinput" /»«/td»«/tr» 


<tr> 
<td></td> 


<td><input type="submit" class="btn" value=" 确 定 修改 " /></td> 


«/tr» 
«/table» 
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</form> 
</div> 
</div> 
</div> 
<?php include('foot.php');?>// 底 部 文件 


4. 管理 员 修 改 自己 的 密码 


前 面 讲 的 是 超级 管理 员 修改 管理 员 的 操作 ， 但 是 许多 时 候 管理 员 自 己 也 要 修改 自己 的 
密码 。 下 面 通过 一 段 代码 进行 讲解 ， 其 代码 (setting_password.php) 如 下 : 


<?php include ('head.php') ;2?>// 调 入 头 部 文件 
<?php $setting = $res->get('setting');2>// 获 得 设置 


«div id-"setting box"» 
«div id-"setting nav"» 
«?php include('setting nav.php'); ?>// 获 得 导航 文件 
</div> 
<div id="setting body"> 
<div id="change pass" class="stab"> 
«form method-"post" action-"admin.php?ctl-setting&act 
=password" onsubmit-"check form(this);return false;"» 
«table» 
«tr» 
«td class="tt"> 原 密码 :</td> 
<td><input class-"txtinput" type-"password" name-"oldpass" /»«/td» 
«/tr» 
«tr» 
«td class="tt"> 新 密码 :</td> 
«td»«input class-"txtinput" type-"password" name-"newpass" /»«/td» 
«/tr» 
«tr» 
«td class="tt"> 再 次 输入 密码 :</td> 
<td><input class-"txtinput" type-"password" name-"passagain" /></td> 
«/tr» 
«tr» 
«td»«/td» 
<td><input type="submit" class="btn" value=" 修 改 密码 " /»«/td» 
</tr> 
</table> 
</form> 
</div> 
</div> 
</div> 
<?php include ('foot.php');2>// 底 部 文件 


5. 生成 图 片 信息 
当 图 片上 传 后 ， 系 统 会 抓 取 当前 时 间 处 理 图 片 。 下 面 通过 一 段 代 码 进行 讲解 ， 其 代码 
(setting task.php) 如 下 : 


<?php include('head.php');?>// 调 入 头 部 文件 
<?php $setting = $res-»get('setting');?»//iX 


«div id-"setting box"» 
«div id-"setting nav"» 
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<?php include('setting nav.php'); ?>// 调 入 导航 文件 
</div> 
<div id="setting body"> 
<div id="operator setting" class="stab"> 
<div style-"text-align:left;"»«input type="button" class="btn" 
value=" 处 理 所 有 图 片 " onclick="window.location.href= 
'admin.php?ctl-setting&act-dotask';"»«/div» 
«table» 
«?php 
if($res-»get('tasks')): 
foreach($res-»get('tasks') as $v): ?>// 获 取 任 务 
«tr» 
<td><?php echo $v['name'] ?>// 显 示 姓 名 </td 
<td><?php echo date('Y-m-d H:i:s',$v['create time']);?>// 


显示 日 期 
«/td» 
<td> 待 生成 缩 略图 </td> 
«/tr» 
<?php endforeach; // 搜 索 完毕 
endif; ?> 
</table> 
«div class="pageset"><?php echo $res-»get ('pageset');?>// 页 面 设置 </div> 
</div></div></div> 


<?php include('foot.php');?>// 底 部 文件 


3.5.6 上传 图 片 

上 传 图 片 是 本 系统 的 核心 之 一 ， 可 以 说 没有 图 片上 传 功能 ， 本 系统 将 丝毫 没有 意义 ， 
下 面 通 过 几 段 代码 进行 讲解 如 何 完成 上 传 图 片 功能 。 

1. 上 传 图 片 首 页 

上 传 图 片 首 页 实际 上 就 是 用 户 根据 需要 将 上 传 的 图 片 放 在 哪 一 类 ， 选 择 好 就 可 以 了 ， 
如 图 3-14 所 示 。 
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3-14 上传 图 片 首页 


下 面 通过 一 段 代码 进行 讲解 ， 其 代码 (upload_step1.php) 如 下 : 


<?php include('head.php');?>// 头 部 文件 
<div id="upload help"> 


人 = 
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«span class="current"> 第 一 步 : 选择 相册 并 上 传 图 片 </span> >> 
<span> 第 二 步 : 上 传 图 片 </span> >> 
<span> 第 三 步 : 查看 结果 </span> >> 


<span> 完 成 </span> 
</div> 
<div id="sel album"> 
选择 相册 : 
<select name="albums"> 
<?php 
$ls = $res->get ('albums list'); 
if ($1s){ 
foreach ($ls as $v)( 
echo " 


<option value-V'".$v['id']."V"»".$v['name']."«/option» An"; 
) 
} 
2> 
</select> <input type="button" style="margin-left:10px;" 
class-"btn" onclick-"create album(0)" value=" 新 建 相册 " /> 
<div class="buttons"><input class="btn" type="button" value= 
"下 一 步 " onclick-"go upload step2()" /></div> 
</div> 
<?php include('foot.php');?>// 底 部 文件 


2. 普通 上 传 


选择 相册 后 ， 用 户 可 以 浏览 图 片 ， 将 选择 的 图 片 一 一 添加 到 系统 中 ， 然 后 单 击 提交 按 
钮 进行 上 传 ， 如 图 3-15 所 示 。 
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图 3-15 上 传 图 片 
下 面 通过 一 段 代 码 进行 讲解 ， 其 代码 (upload_step2_1.php) 如 下 : 
<?php include ('head.php') ;2>// 头 部 文件 
«div id-"upload help"> 
<span> 第 一 步 : 选择 相册 并 上 传 图 片 </span> »» 
«span class="current"> 第 二 步 : 上 传 图 片 </span> >> 
<span> 第 三 步 : 查看 结果 </span> >> 


<span> 完 成 </span> 
</div> 
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<div id="upload field"> 
<form id="upload photos form" method="post" enctype="multipart/form-data" 
action-"admin.php?ctl-upload&act-dopicupload&album- 
<?php echo $res-»get('album id')?»"» 
<div id-"uploader" style="width: 100%; height: 210px;margin:lO0px;"» 
请 选择 您 要 上 传 的 图 片 : «br /><br /> 


1. «input name-"imgs[]" /><br /><br /> 

2. «input name-"imgs[]" /»«br /»«br /» 

3. «input name-"imgs[]" /»«br /»«br /» 

4. «input name-"imgs[]" /><br /»«br /> 

5. «input name-"imgs[]" /><br /><br /> 
«/div» 


«div align-"left"»«input type="submit" class="btn" 

value=" 下 一 步 " /»«/div» 

</form> 

<br /> 

«a href-"admin.php?ctl-upload&act-step2&album id= 

<?php echo $res-»get('album id') ?>// 相 短 ia 号 "> 高 级 上 传 模式 </a> 
«/div» 


<?php include ('foot.php') ;2?>// 底 部 文件 
3. 高 级 上 传 功能 


选择 相册 后 ， 用 户 就 需要 选择 上 传 的 图 片 ， 本 系统 用 户 可 以 选择 多 张 图 片 进行 上 传 ， 
如 图 3-16 所 示 。 
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3-16 选择 图 片 
下 面 通过 一 段 代 码 进行 讲解 ， 其 代码 (upload_step2.php) 如 下 : 


<?php include ('head.php') ;2>// 调 入 头 部 文件 

<link rel="stylesheet" href-"img/plupload/plupload.queue.css" 
type="text/css" /> 

<script type="text/javascript" src="js/gears init.js"></script> 

<script type="text/javascript" src="js/plupload.full.min.js"></script> 

<script type="text/javascript" 
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src-"js/jquery.plupload.queue.min.js"»«/script» 
«script» 
S$(function() { 

plupload.addI18n(( 

'Select files' : ' 选 择 图 片 '， 

'Add files to the upload queue and click the start button.' :' 添 加 图 片 
并 单 击 开始 按钮 , 可 以 同时 选择 多 个 图 片 。'， 

"Filename' : ' 文 件 名 '， 

"Status' z E", 

'Size' : "大 小 "， 

'Add files' : ' 添 加 文件 '， 

'Stop current upload' : ' 停 止 上 传 '， 

'Start uploading queue' : ' 开 始 上 传 '， 

'Start upload' <- "JR ETEN, 

'Drag files here.' : '" 拖 电文 件 至 此 处 ." 

n; 


$("4flash uploader").pluploadQueue(( 
runtimes : 'html5,flash,gears,silverlight,browserplus,html4', 


url : 'admin.php?ctl-upload&act-process', 
max file size : 'lOmb', 
chunk size : '1mb', 


unique names : true, 
filters : [ 
(title : "Image files", extensions : "jpg, jpeg,gif,png") 
l, 
<?php if($res-»get('open pre resize')):?»resize : (width : 
«?php echo 
$res-»get('resize img width');?», height : «?php echo 
$res-»get('resize img height');?», quality : «?php echo 
$res-»get('resize quality');?»), 
«?php endif;?» 
flash swf url : 'js/plupload.flash.swf', //2Jili 
silverlight xap url : 'js/plupload.silverlight.xap' 
); 


var usubmited - 0; 
$('£upload photos form').submit(function(e) ( 
var uploader = $('4flash uploader').pluploadQueue(); 
if (uploader.total.uploaded — 0) ( 
if (uploader.files.length > 0) ( 
uploader.bind('UploadProgress', function() ( 
if (uploader.total.uploaded == uploader.files.length && usubmited == 0)( 
$('£upload photos form').submit(); 
usubmited = 1; 
} 
):; 


uploader .start () ;// 上 传 开 始 
} else 


alert (' 至 少 选择 一 个 文件 上 传 . ' ) ; 


e.preventDefault () ; 
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</script> 

<div id="upload help"> 
<span> 第 一 步 : 选择 相册 并 上 传 图 片 </span> >> 
«span clas "current"> 第 二 步 : 上 传 图 片 </span> >> 
<span> 第 三 步 : 查看 结果 </span> >> 
<span> 完 成 </span> 

</div> 


<div id="upload field"> 
«form id-"upload photos form" method-"post" 
action-"admin.php?ctl-upload&act-doupload&album- 
<?php echo $res-»get('album id')?»"» 
«div id-"flash uploader" style="width: 100%; height: 330px;margin-top:10px;"» 
Loading.... 
«/div» 
«div align-"center"»«input type-"submit" class-"btn" value=" 下 一 步 " /> 
«/div» 
«/form» 


<a href-"admin.php?ctl-upload&act-step2 l&album id= 
<?php echo $res-»get('album id')?>"> 普 通 上 传 模式 </a> 
</div> 
<?php include('foot.php');?>// 底 部 文件 


4. 完成 上 传 


当 用 户 完成 上 传 图 片 后 ， 系 统 将 提示 用 户 已 经 上 传 完毕 ， 下 面 通过 一 段 代 码 进行 讲解 ， 
其 代码 (upload_step3.php) 如 下 : 


<?php include ('head.php');?>// 头 部 文件 

<div id="upload help"> 
<span> 第 一 步 : 选择 相册 并 上 传 图 片 </span> >> 
<span> 第 二 步 ， 上 传 图 片 </span> >> 
<span class="current"> 第 三 步 : 查看 结果 </span> >> 
<span> 完 成 </span> 

</div> 


<div id="save album"> 

<div class="line"><img src="img/loading.gif" /></div> 

«div class-"line" style-"font-size:36px;line-height:80px;"» 

上 传 成 功 ， 程 序 正在 处 理 图 片 !</div> 

«div class="1line"> 您 也 可 以 

«a href-"admin.php?ctl-album&act-photos&album- 

<?php echo $res->get ('album');?>"> 离 开 此 页 面 </a> 让 后 端 自 动 处 理 ! </div> 
</div> 


<?php include('foot.php');?» 

«script type-"text/javascript" src-"admin.php?ctl-photo&act-resize&album- 
<?php echo $res-»get ('album');?» 

&time-«?php echo time();?»"»«/script» 


图 片上 传 后 ， 将 会 弹出 如 图 3-17 所 示 的 信息 。 
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上 传 成 功 ， 程 序 正 在 处 理 图 片 ! 
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图 3-17 ”上传 图 片 完成 


3.5.7 ”相册 的 后 台 展 示 


当 用 户 上 传 图 片 后 ， 可 以 根据 需要 对 图 片 进行 编辑 ， 如 设置 拍摄 信息 、 设 置 预览 图 片 


大 小 等 ， 如 图 3-18 所 示 。 
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3-18 ”图 片 浏览 
下 面 通过 一 段 代码 进行 讲解 ， 其 代码 (viewphoto.php) 如 下 : 
<?php include('head.php');?>// 头 部 文件 
<?php $ls = $res-»get('pic');?» 


<?php $pre pic = $res-»get('pre pic');?> 
<?php $next pic = $res-»get('next pic');?» 


< 
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«div id-"allpic"» 
«div id-"album nav" class-"album detail"» 
«hl class-"album title"»«?php echo $1s['name']; ?>// 显 示 名 称 </h1> 
«div class="photoinfo"> 
上 传 时 间 : <?php echo date('Y-m-d H:i:s',$l1s['create time']); ?> 
«input type-"button" class-"btn" 
onclick-"window.location.href-'admin.php?ctl-album&act-photos&album- 
<?php echo $1s['album'];?»'" value=" 返 回 
<?php echo $res-»get('album name'); ?>" 
/»«/div» 
«/div» 
«div id-"photo-body"» 
«div class-"picnt"» 
«img class-"p-tag" src-"img/pic loading.gif"» 
«/div» 
«/div» 
«div class-"photo-right"» 
«input type="button" class="btn" value=" 拍 摄 信 息 " onclick-"show exif (this)" 
/? 
«div id-"exif info"» 
«div class-"top"»«a href-"javascript:void(0)" 
onclick-"close exif()"> 拍 摄 信息 </a></div> 
<?php if($rs = $res-»get('imgexif'))(?» 
«div class-"content"» 
«ul» 
<?php foreach($rs as $k-»$v):?» 
<li><span class-"exif tit"»«?php echo $k;?» 
</span><span class-"exif val"»«?php echo $v;?»«/span»«/li» 
<?php endforeach;?» 
«/ul» 
«/div» 
<?php Jelse(?» 
«div class-"content"»«div class="inf"> 没 有 EXIF 信息 ! «/div»«/div» 
«?php ) ?» 
«/div» 


«div id-"photo control"» 
«ul» 

<?php if($pre pic): ?> 

<li><a href-"admin.php?ctl-photo&act-view&id- 
<?php echo $pre pic['id'];?»&album- 
<?php echo $res-»get ("album");?»4photo-body"»«img src= 
"<?php echo mkImgLink($pre pic['dir'],$pre pic['pickey'],$pre pic['ext'], 
'square');?»" /»«/a»«/li» 

<?php else:?» 

<1i> 这 是 首 张 </1i> 

«?php endif;?> 

«li class="current"><a href="javascript:void(0)"><img src=" 
<?php echo mkImgLink($1s['dir'],$1s['pickey'],$1s['ext'], 'square');?»" 
/»«/a»«/li» 


<?php if($next pic): ?> 

<li><a href-"admin.php?ctl-photo&act-view&id- 
<?php echo $next pic['id'];?»&album- 
<?php echo $res-»get ("album");?»4photo-body"»«img src= 
"<?php echo mkImgLink 
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(Snext pic['dir'],$next pic['pickey'],$next pic['ext'],'square');?»" 


/»«/a»«/1li» 
«?php else:?» 
<1i> 这 是 末 张 </1i> 
«?php endif;?> 
«/ul» 


«div class-"prebtn"»«?php if($pre pic): ?> 
«a class-"btnpre" href-"admin.php?ctl-photo&act-view&id- 
<?php echo $pre pic['id'];?»&album- 
<?php echo $res-»get ("album"); ?»4photo-body"» l.—3K«/a» 
<?php endif;?»«/div»«div class-"nextbtn"»«?php if($next pic): ?> 
«a class-"btnnext" href-"admin.php?ctl-photo&act-view&id- 
<?php echo $next pic['id'];?»&album- 
<?php echo $res-»get ("album"); ?»£photo-body"» F—sK«/a» 
<?php endif;?»«/div»«div class-"slideshow"» 
«a href-"javascript:void(0)" onclick-"slideshow( 
<?php echo $res-»get ("album") ;?>) "»A]A] y «/a»«/div» 
«/div» 
«div id-"copyspics"» 
«textarea id-"copyspics content" 
style-"margin-left:4px;width:250px;height:150px;"»«/textarea»«br /> 
选择 图 片 大 小 : «br /> 
«input type-"radio" name-"size" value- 
"<?php echo SITE URL.mkImgLink($1s['dir'],$1s['pickey'],$1s['ext'], 
'square');?»" onclick-"select copypics(this.value)" /> 方块 图 (75*75) 
«a href-"«?php echo SITE URL.mkImgLink($1s['dir'],$1s['pickey'], 
$1s['ext'], 'square');?»" target-" blank"> 预 览 </a><br /> 
«input type-"radio" name-"size" Value= 
"<?php echo SITE URL.mkImgLink($1s['dir'], 
$1s['pickey'],$1s['ext'], 'thumb');?»" 
onclick-"select copypics(this.value)" /» 缩 略图 (110*150) 
«a href-"«?php echo SITE URL.mkImgLink($1s['dir'], 
$1s['pickey'],$1s['ext'], 'thumb');?»" target-" blank"> 预 览 </a><br /> 
«input type-"radio" name-"size" value- 
"<?php echo SITE URL.mkImgLink($1s['dir'],$1s['pickey'], 
$1s['ext'],'small');?»" 
onclick-"select copypics(this.value)" /» 小 图 (240*240) 
«a href-"«?php echo SITE URL.mkImgLink ($1s['dir'],$1s['pickey'], 
$1s['ext'],'small');?»" target="”blank"> 预 览 </a><br /> 
«input type-"radio" name-"size" value- 
"<?php echo SITE URL.mkImgLink($1s['dir'],$1s['pickey'], 
$1s['ext'],'medium');?»" onclick-"select copypics (this.value)" 
checked-"checked" /> 中 图 (550*550) «a href- 
"<?php echo SITE URL.mkImgLink($1s['dir'], 
$1s['pickey'],$1s['ext'], 'medium');?»" target-" blank"> 预 览 </a><br /> 
«input type-"radio" name-"size" value-" 
<?php echo SITE URL.mkImgLink($1s['dir'], 
$1s['pickey'],$1s['ext'], 'big');?»" onclick-"select copypics (this.value)" 
/> 大 图 (900*900) «a href- 
"<?php echo SITE URL.mkImgLink($1s['dir'],$1s['pickey'], 
$1s['ext'],'big');?»" target-" blank"> 预 览 </a><br /> 
«input type="radio" name-"size" value=" 
<?php echo SITE URL.mkImgLink($1s['dir'],$1s['pickey'], 
$1s['ext'],'orig');?»" onclick-"select copypics(this.value)" /> 原 图 
«a href-"«?php echo SITE URL.mkImgLink($1s['dir'],$1s['pickey'], 
$Sls['ext'],'orig');?»" target-" blank"> 预 览 </a><br /»«br /> 


«input type-"button" value=" 复 制 到 剪 切 板 "” class="btn" 
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id-"copyspics click" /> 
«/div» 
«/div» 
<div class-"clearfix"»«/div» 
«/div» 
<?php include('foot.php');?» 
<script type-"text/javascript"» 
function select copypics (url)( 
$("$copyspics textarea").val('«div align="center"> 
«img src-"'«urle'" /»«/div»«br /»'); 
H 


$(function (){ 
var select url = $('#copyspics input [name-size]:checked').val(); 
select copypics(select url); 
«?php 
if($next pic){ 
?» 
var imghref - 'admin.php?ctl-photo&act-view&id- 
<?php echo $next pic['id'];?»&album- 
<?php echo $res-»get ("album"); ?»$4photo-body'; 
var nexttile = " 单 击 查看 下 一 张 "7 
<?php 
}else{ 
?» 
var imghref = 'javascript:void(0)'; 
var nexttile = ' 已 经 是 最 后 一 张 ' ; 
<?php 
) 
?» 
var img - new Image(); 
img.onload = function (){ 
var img width = img.width; 
var max width = $('body').width()-350; 
if (img.width » max width) ( 
img width = max width; 
n 
var imgload = '«div class-"shl"» 
«div class-"sh2"»«div class-"sh3"» 
«a class-"p-tag" hidefocus-"true" href-"'«imghref*'" title= 
"'énexttile-'"»«img class-"p-tag" width-"'«img width*'" src= 
"'cimg.srce'"»«/a»«/div»«/div»«/div»'; 
$('£photo-body div.picnt').html (imgload); 
n 
img.src = "«?php echo 
mkImgLink($1s['dir'],$1s['pickey'],$1s['ext'], 'big') ;?»"; 


var clip = new ZeroClipboard.Client(); 
clip.setText(''); 
clip.setHandCursor( true ); 
clip.glue('copyspics click'); 
clip.addEventListener('mouseOver',function(client) ( 
clip.setText ($('4copyspics content').val()); 
H? 
clip.addEventListener ('complete', function (o) { 
var pos = getElementOffset ($ ('#copyspics click').get(0)); 
$ ('#copyedok') .css('left',pos.left); 
$ ('#copyedok') .css('top',pos.top+22); 


$ ('#copyedok') .show() .animate ({opacity: 1.0}, 1000) .fadeout () ; 
n; 
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window.onresize = function (){ 
var img width = img.width; 
var max width = $('body').width()-350; 
if (img.width > max width) { 
img width = max width; 
E 
$('fphoto-body img').attr('width',img width); 
clip.reposition('copyspics click'); 
n 
document.onkeydown = keydown; 
function keydown (event) { 
event = event ? event : (window.event ? window.event : null); 
if ($("#photo control").find("a.btnpre").length > 
0 && event.keyCode--37) ( 
window.location-$ ("£photo control").find("a.btnpre").attr("href"); 
) 
if ($("#photo control").find("a.btnnext").length > 
0 && event.keyCode--39) ( 
window.location-$ ("£photo control").find("a.btnnext").attr("href"); 
) ) 


n; 
«/script» 


， 深 思 后 各 设计 


完成 了 后 台 设 计 工 作 后 ， 整 个 项 目的 工作 就 基本 结束 了 。 经 过 本 阶段 的 工作 之 后 ， 我 
了 解 了 后 台 设 计 的 功能 其 实 就 是 管理 前 台 和 管理 基本 信息 。 作 为 一 名 初学 者 ， 在 开发 后 台 
时 ， 很 容易 思路 理 不 清 而 走 弯 路 ， 只 有 和 弄 清楚 了 各 个 相册 功能 的 关系 之 后 ， 才 能 顺利 的 开 
发 完整 的 后 台 功 能 。 


3.6 为 相册 建立 模型 


[03:063 129 209, d, 5498 

刚刚 结束 后 台 设 计 和 编码 工作 ， 整 个 项 目 也 随 之 告 一 段落 。 傍 晚 ， 我 在 脑海 中 又 演示 
了 一 遍 整 个 项 目 ， 发 现 不 管 是 前 台 还 是 后 台 ， 我 们 编写 的 代码 是 无 法 将 整个 系统 表现 得 那 
么 完美 的 ， 还 有 必要 建立 一 个 模型 的 代码 以 供 前 台 调用 。 


3.6.1 上 传 功能 的 模型 


上 传 是 整个 系统 至 关 重 要 的 功能 ， 当 建立 模型 时 ， 同 样 为 上 传 建立 了 一 些 功 能 ， 供 用 
户 上 传 时 使 用 ， 下 面 通过 一 段 代码 进行 讲解 ， 其 代码 如 下 
«?php 
// 建 立 上 传 功能 的 类 
class upload extends modelfactory( 
// 删 除 图 片 文 件 
function delpicfile ($dir, $key, $ext) {// 删 除 图 片 文件 
$list = array('small','square', 'medium', 'big', 'thumb', 'orig'); 


// 列 表 


v. [ 
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foreach ($list as $v) {// 搜 索 
@unlink (ROOTDIR.mkImgLink ($dir, $key, $ext, $v) ) 
b 


} 
// 图 片 属性 
function generatepic ($dir, $key, $ext) { 
// 图 片 基本 属性 
ignore user abort (true); 
$realpath = ROOTDIR.mkImgLink ($dir, $key, $ext, 'orig'); 
// 返 回 规范 的 绝对 路 径 名 
include once (LIBDIR.'image.class.php');// 插 入 列表 
$imgobj = new Image(); 
$size = 'big';//X'/h 
$width = '900';// 宽 度 
$height = '900';// 高 度 
$bigpath = ROOTDIR.mkImgLink ($dir, $key, $ext, $size) ;// 大 的 路 径 
$imgobj->load ($realpath); 
$imgobj-»setQuality (95) ;// 集 合 质量 
$orgwidth = $imgobj->getWidth () ;// 宽 度 
$orgheight = $imgobj->getHeight ();// 高 度 
if(Sorgwidth <= $width && $orgheight <= $height){ 
copy ($realpath, $bigpath); 
}else{ 
$imgobj->resizeScale ($width, $height ); 
$imgobj->save ($bigpath); 
} 
@chmod ($bigpath, 0755) ;// 更 改 文件 属性 
$size = 'medium';// 中 间 值 
$width = '550';// 宽 度 
$height = '550';// 高 度 
$newpath = ROOTDIR.mkImgLink ($dir, $key, $ext, $size); 
if(Sorgwidth <= $width && $orgheight <= $height) { 
copy ($realpath, $newpath) ; 
}else{ 
$imgobj->load ($bigpath); 
$imgobj-»resizeScale ($width, $height); 
$imgobj-»save ($newpath) ; 
) 
Gchmod ($newpath, 0755) ; // 更 改 文件 属性 
$size = 'small'; 
$width = '240';// 宽 度 
$height = '240';// 高 度 
$newpath = ROOTDIR.mkImgLink ($dir, $key, $ext, $size); 
if ($orgwidth <= $width && $orgheight <= $height) { 
copy ($realpath, $newpath) ; 
jersei 
$imgobj->load (Sbigpath) ;// 载 入 
$imgobj-»resizeScale ($width, $height ); 
$imgobj-»save ($newpath) ; // 保 存 路 径 
} 
@chmod ($newpath, 0755) ; 


$size = 'thumb';// 缩 小 图 

$width = '110';//XXE 

$height = '150';// 高 度 

$newpath = ROOTDIR.mkImgLink ($dir, $key, $ext, $size);// 新 的 路 径 
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if(Sorgwidth <= $width && $orgheight <= $height){ 
copy ($realpath, $newpath) ;// 赋 值 信息 

}else{ 
$imgobj->load ($bigpath) ; 
$imgobj->resizeScale ($width, $height );// 调 入 高 度 
$imgobj-»save ($newpath) ; 

} 

@chmod ($newpath, 0755) ; 


$size = 'square'; 

$width = '75'; 

$newpath = ROOTDIR.mkImgLink ($dir, $key, $ext, $size); 

if(Sorgwidth <= $width && $orgheight <= $width){ 
copy ($realpath, $newpath) ; 

}else{ 
$imgobj->load ($bigpath) ;// 大 的 图 片 
$imgobj-»square ($width) ;// 正 方形 图 片 
$imgobj-»save ($newpath) ;// 新 的 图 片 

echmod ($newpath, 0755) ;// 更 改 文件 属性 

) 


function addwater ($realpath) {// 添 加 
global $setting;// 设 定 
if (isset ($setting['open watermark']) && $setting['open watermark']—-true)( 
include once (LIBDIR.'image.class.php');// 调 入 页 面 
$imgobj = new Image();// 新 的 图 片 
$imgobj->load ($realpath) ; 
if ($imgobj->image type != IMAGETYPE GIF) { 
$imgobj->setQuality (95); 
$imgobj->waterMark ($setting['watermark path'],$setting 
['watermark pos']); 
$imgobj-»save ($realpath); 
j; 
) 


} 
// 上 传 属性 获取 
function plupload(){ 
header('Content-type: text/plain; charset=UTF-8');// 字 符 集 
header ("Expires: Mon, 26 Jul 1997 05:00:00 GMT");// 时 间 
header("Last-Modified: " . gmdate("D, d M Y H:i:s") . " GMT"); 
// 末 尾 日 期 
header ("Cache-Control: no-store, no-cache, must-revalidate");// 缓 冲 管理 
header ("Cache-Control: post-check=0, pre-check=0", false); 
header("Pragma: no-cache");// 编 译 指示 
$tmp dir = where is tmp(); 
$targetDir = $tmp dir. DIRECTORY SEPARATOR . "plupload"; 
$cleanupTargetDir = false; // 移 除 旧 的 临时 文件 
$maxFileAge = 60 * 60; // 临 时 文件 超时 时 间 
// 5 分 钟 的 执行 时 间 
@set time limit(5 * 60); 
$chunk = isset($ REQUEST["chunk"]) ? $ REQUEST["chunk"] : 0;// 大 块 设置 
$chunks = isset ($ REQUEST ["chunks"]) E^ $ REQUEST["chunks"] : 0; 
$fileName = isset($ REQUEST["name"]) ? $ REQUEST["name"] : '';//HjP' 
$fileName = preg replace('/[^NwN. ]*/', '', S$fileName); 
if (!file exists ($targetDir)) 
@mkdir ($targetDir); 
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if (is dir($targetDir) && ($dir = opendir($targetDir))) ( 
while (($file = readdir($dir)) !== false) ( 
$filePath = $targetDir . DIRECTORY SEPARATOR . $file; 
if (preg match('/NN.tmp$/', $file) && (filemtime ($filePath) 
« time() - $maxFileAge)) 
Qunlink($filePath);]) 
closedir ($dir); 
) else 
die('("jsonrpc" : "2.0", "error" : ["code": 100, "message": 
"Failed to open temp directory."), "id" : "id")'); 
// 查看 header 信息 : content type 
if (isset($ SERVER["HTTP CONTENT TYPE"])) 
$contentType = $ SERVER["HTTP CONTENT TYPE"] ; // 容 量 类 型 
if (isset($ SERVER["CONTENT TYPE"] ) ) // 设 置 
$contentType = $ SERVER["CONTENT TYPE"]; 
if (strpos($contentType, "multipart") !== false) {// 返 回 一 个 字符 串 
if (isset($ FILES['file']['tmp name']) && 
is uploaded file($ FILES['file']['tmp name'])) ( 
$out = fopen($targetDir . DIRECTORY SEPARATOR . $fileName, 
$chunk == 0 ? "wb" : "ab"); 
if ($out) ( 
$in = fopen($ FILES['file']['tmp name'], "rb");// 打 开 文件 
if ($in) ( 
while ($buff = fread($in, 4096)) 
fwrite($out, $buff); 
) else 
die('("jsonrpc" : "2.0", "error" : ("code": 101, "message": 
"Failed to open input 
stream."), "id" : "id"}');// 错 误 提 示 
fclose ($out); 
unlink ($_FILES['file'] ['tmp_name']);// 找 不 到 文件 
) else 
die('("jsonrpc" : "2.0", "error" : ("code": 102, "message": 
"Failed to open output stream."), "id" : "id"}")7// 提 示 打 开 输出 文件 失败 
p else 
die('("jsonrpc" : "2.0", "error" : ("code": 103, "message": 
"Failed to move uploaded file."), "id" : "id")'); 提示 打开 输出 文件 失败 
) else ( 
$out = fopen($targetDir . DIRECTORY SEPARATOR . $fileName, 
Schunk == 0 ? "wb" : "ab"); 
if (Sout) ( 
$in = fopen("php://input", "rb");//1]JFX41l 
if ($in) ( 
while ($buff = fread($in, 4096)) 
fwrite ($out, $buff); 
} else 
die('("jsonrpc" : "2.0", "error" : ("code": 101, "message": 
"Failed to open input stream."), "id" : "id"}');// 提 示 信 息 
fclose ($out); 


} else 
die('['"jsonrpc" < "2-0", "error" 2 ("code": 102, 
"message": "Failed to open output stream."), "id" : "id"}');}// 提 示 信 息 
dieu sonrec. 062-077 Mrosulte a mill, Mid = Sade Ns 
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3.6.2 ”设置 系统 的 模型 


在 后 台 管理 时 需要 设置 系统 。 设 置 系统 同样 是 十 分 重要 的 功能 ， 完 成 简单 的 功能 上 几 
节 的 讲解 就 可 以 实现 ， 如 果 要 完成 更 强 的 功能 ， 高 不 开 下 面 的 代码 ， 代 码 (setting.php) 如 下 : 


«?php 
// 建 立 设置 类 
class setting extends modelfactory( 
// 保 存 设置 
function save setting(Snew setting)( 
$basedir = defined('REWRITE BASE')?REWRITE BASE:get basepath(); 
// 数 据 目录 
$htaccess content = '«ifmodule mod rewrite.c>// 不 履行 连接 
RewriteEngine On 
RewriteBase ' .$basedir.'data// 重 写 基础 类 
Options +FollowSymLinks'."\n"; 
if($new setting['access ctl'] == 'true')( 
if('' != trim($new setting['access domain']))( 
$htaccess content .= '#access'."\n";// 不 履行 目录 
$htaccess content .= 'RewriteCond $(HTTP REFERER} !^$ [NC]'."\n"; 
$access arr = explode ("\n",$new setting['access domain']); 
// 文 件 设置 
foreach ($access arr as $v)( 
if('' != trim($v))( 
$htaccess content .= 'RewriteCond $(HTTP REFERER) !^ 
(http|https)://'.trim($v).' [NC]'."\n";// 目 录 权限 
d 
$htaccess content .= 'RewriteRule .// 可 写 目 录 
*\. (jPgljPeglgiflpng)$ ../img/noaccess.jpg [NC,L]'."An"; 
1 


if($new setting['demand resize'] == 'true')( 
$htaccess content .= '#auto resize'."An"; 
$htaccess content .= 'RewriteCond $(REQUEST FILENAME) !-f 
RewriteRule .*/(.*) (.*)N. (jPgdljPeglgiflpng)$ ../index.php?ctl-photo&act 
-resize&size-$2&key-$1 [NC,L]'."Vn"; ) //H] 53 Hok3cf 2878 
$htaccess content .= '«/ifmodule»'; 
if($new setting['demand resize'] -- 'true' || 
$new setting['access ctl'] -- 'true')( 
efile put contents (DATADIR.'.htaccess',$htaccess content); 
G chmod (DATADIR.'.htaccess',0755); 
}else{ 
Gunlink(DATADIR.'.htaccess');] 
$setting content = "<?php Wn"; 
$setting content .= "VX$setting['site title'] = 
'".html replace($new setting['site title'])."';An"; 
$setting content .= "VA$setting['site keyword'] = 
'".html replace($new setting['site keyword'])."'; An"; //U EX ty 


// 设 置 站 点 连接 描写 
$setting content .= "\$setting['site description'] = 
'".html replace($new setting['site description'])."';\n"; 
// 设 置 链接 
$setting content .= "A$setting['url'] = '".$new setting['url']."';\n"; 
// 设 置 前 级 
$setting content .= "\$setting['open pre resize'] = 


".$new setting['open pre resize'].";Wn"; 
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// 设 置 图 片 宽度 

$setting content .= "\$setting['resize img width'] = 
'".$new setting['resize img width']."';Wn"; 
// 设 置 图 片 高 度 

$setting content .= "\$setting['resize img height'] = 
'".$new setting['resize img height']."';An"; 
// 设 置 图 片 质量 

$setting content .= "\$setting['resize quality'] = 
'".$new setting['resize quality']."'; An"; 
// 设 置 图 片 空间 


$setting content .= "X$setting['demand resize'] = 
".$new setting['demand resize']."; Mn"; 
// 设 置 图 片 类 型 
$setting content .= "X$setting['imgdir type'] = 
'".$new setting['imgdir type']."';Wn"; 
$setting content .= "X$setting['size allow'] 
'".$new setting['size allow']."';WAn"; 
// 设 置 页 面 保存 
$setting content .= "\$setting['pageset'] = 
'".$new setting['pageset']."'; An"; 
// 打 开 图 片 
$setting content .= "\$setting['open photo'] 
".$new setting['open photo']."; An"; 
// 设 置 图 片 限 制 
$setting content .= "\$setting['gallery limit'] 
'".$new setting['gallery limit']."'; Wn"; 
// 设 置 图 片 权限 
$setting content .= "\$setting['access ctl'] = 
".$new setting['access ctl'].";WMn"; 
// 设 置 图 片 领域 
$setting content .= "VX$setting['access domain'] 
'".html replace($new setting['access domain'])."'; An"; 
// 设 置 水 印 
$setting content .= "X$setting['open watermark'] 
".$new setting['open watermark'].";Wn"; 
// 水 印 图 片 路 径 
$setting content .= "\$setting['watermark path'] 
'".html replace($new setting['watermark path'])."';Wn"; 
// 设 置 水 印 点 
$setting content .= "X$setting['watermark pos'] = 
'".$new setting['watermark pos']."'; Mn"; 
$setting content .= "2>"7 
return 
Gfile put contents (ROOTDIR.'conf/setting.php',$setting content);] 
// 获 取 设 置信 息 
function get setting()( 
global $setting; 
if(!isset($setting['open watermark']))( 
$setting['open watermark'] = false;] 
if(!isset($setting['watermark path']))t 


$setting['watermark path'] = '';J 
if(!isset($setting['watermark pos']))( 
$setting['watermark pos'] = 0; H 


return $setting; 
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3.6.3 图 片 的 模型 


展示 图 片 是 本 系统 又 一 核心 的 功能 ， 它 也 有 自己 的 模型 ， 下 面 通过 一 段 代 码 进 行 讲解 ， 
代码 (picture php) 如 下 。 


«?php 
// 建 立 一 个 图 片 模型 类 
class picture extends modelfactory( 
// 得 到 所 有 图 片 
function get all pic($page = 
NULL,$album-0,$sort-'time desc',$limit-0,$filter private-false)( 
$where - 'status-1'; 
// 判 断 
if($album > O)( 
$where .= ' and album-'.intval ($album);} 
if ($filter private)( 
$where .= ' and private=0';} 
if ($sort == 'hot'){ 
$db sort = 'hits desc,id desc'; 
}elseif ($sort 'time asc')( 


T 


$db sort = 'create time asc'; 
}else{ 
$db sort = 'create time desc';} 


$this->db->select ('#imgs',"*", $where, $db sort); 
if ($page) { 
$pics = $this->db->toPage ($page, PAGE SET); 
}else{ 
if ($limit > 0){ 
$this->db->selectLimit (NULL, $limit); } 
$pics = $this-»db-»getAll();] 
return $pics;]) 
// 获 取 缓存 图 片 
function get tmp pic($page = NULL)( 
$this-»db-»select('£imgs','*','status-3','id asc'); 
if ($page) { 
return $this->db->toPage ($page, PAGE SET); } 
return $this-»db-»getAll();] 
function get one pic($id)( 
$this-»db-»select('fimgs','*','id-'.intval($id)); 
return $this-»db-»getRow();] 
function get one pic by key($key)( 
$this-»db-»select('f£imgs','*','pickey-"'.$key.'"'); 
return $this-»db-»getRow();]) 
// 获 取 前 置 图 片 
function get pre pic($id,$album-0)( 
$where = 'status-1 and id>'.intval ($id); 
if ($album»0)( 
$where .= ' and album-'.intval ($album);] 
$this-»db-»select('£imgs','*',$where,'id asc limit 1'); 
return $this-»db-»getRow();] 
// 获 取 下 一 幅 图 片 
function get next pic($id,$album-0)( 
$where = 'status-1 and id<'.intval ($id); 
if ($album»0)( 
$where .= ' and album-'.intval ($album);] 
$this-»db-»select('£imgs','*',$where,'id desc limit 1'); 
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return $this-»db-»getRow();! 
// 获 取 插 入 的 图 片 
function insert pic($arr){ 
$this-»db-»insert('£imgs',$arr); 
return $this-»db-»query();) 
function update pic ($id, $name, $album=0) { 
S$arr['name'] = $name; 
$arr['status'] = 1; 
if ($album>0) { 
$album model = & load model('album'); 
$album arr = $album model->get one album (intval ($album)); 
if ($album arr) { 
$arr['private'] = $album arr['private']; 
$arr['album'] = intval($album); } } 
$this->db->update ('#imgs', 'id='.intval ($id), $arr); 
return $this->db->query(); } 
// 删 除 图 片 
function del pic($id)( 
$this-»db-»delete('f£imgs','id-'.intval($id)); 
return $this-»db-»query(); } 
// 获 取 图 片 高 度 c 
function addHit ($id)( 
$this-»db-»update ('f£fimgs','id-'.intval($id),array('hits'-»new 
DB Expr('hits*1'))); 
return $this-»db-»query();]) 
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型 程序 ， 将 功能 进行 延伸 ， 这 样 制作 是 减少 程序 代码 的 最 好 方法 ， 也 是 让 程序 快速 执行 的 
常用 方法 。 
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今夜 静 悄 悄 ， 此 刻 我 们 的 项 目 只 剩 下 系统 测试 和 发 布 的 工作 了 ， 大 家 都 信心 十 足 ， 同 
感觉 很 轻松 。 测 试 工作 表面 看 似 简单 ， 其 实 不 然 。 在 测试 时 一 定 要 细心 ， 尽 力 发 现 可 能 
ee 此 工作 是 由 我 来 完成 的 ， 在 此 我 将 工程 命名 为 “03meiupic”。 
3.7.1 系统 运行 浏览 


现在 开始 运行 测试 ， 如 图 3-19 所 示 是 前 台 查 看 图 片 效果 ， 如 图 3-20 所 示 是 后 台 查 看 图 
片 的 效果 ， 其 他 功能 模块 将 省 略 。 


注意 : 本 项 目的 具体 代码 保存 在 附 赠 光 盘 的 “第 3 章 ” 目 录 下 ， 工 程 名 称 为 “03meiupic” 
请 读者 首先 将 其 复制 到 硬盘 中 ， 去 掉 文 件 的 只 读 属 性 。 


| 120 ES ———————————————————— dads dasd ed. a 


(E snc err menh - 


第 3 章 电子 相册 管理 


[E recti Romo icit 


— OO me EDIDI EFT 2- 


Ee EEA JDEL ^-H- - exe. = iO Ar 


FIDE] ar Aws = 


rr 
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19 前 台 展 示 图 片 


3.72 验收 
| 2006 年 12 月 29 日 ,傍晚 


今夜 的 重 


成 了 影视 学 院 活 动 中 心 的 相册 ， 


庆 下 起 了 雪 ， 重 庆 这 座 
心里 有 一 种 说 不 出 来 的 喜悦 ，DP 和 影视 学 院 几 位 负责 人 非 


图 3-20 后 台 展 示 图 片 


号 称 千 年 不 下 雪 的 城市 ， 却 在 今夜 下 起 了 雪 。 我 们 完 


满意 相册 管理 系统 ， 并 表示 以 后 如 果 有 项 目 会 继续 找 我 们 来 合作 。 


常 满意 


3.7.3 总 结 


这 个 项 目 


的 答卷 ， 因 为 这 个 项 目 关系 到 我 是 否 
终结 果 如 何 现在 还 不 得 知 ， 但 是 绷 紧 和 


经 验 。 


1. 严格 把 握 时 间 
这 个 项 目 从 制作 那天 起 ， 都 需要 


项 目 时 ， 我 们 


每 天 都 有 任务 ， 没 有 任务 完成 就 加 班 完成 。 


2. 界面 的 清新 


我 们 都 是 程序 员 出 身 ， 对 美感 


但 是 我 们 制作 
我 们 制作 的 界 


的 东西 也 不 至 于 矮 一 截 ， 


面 也 十 分 的 清新 。 


是 我 学 习 PHP 来 比较 大 的 一 个 ， 虽 然 历经 波折 ， 但 还 是 给 客户 交 了 一 份 满意 


顺利 通过 "^ 我 在 团队 中 竭尽 全 力 的 工作 。 虽 然 最 
的 心情 有 所 放松 了 。 整 个 过 程 中 我 总 结 出 了 如 下 4 点 


严格 按照 进度 执行 ， 不 然 难以 完成 任务 。 在 制作 这 个 


a Rh 学 院 出 身 的 行家 相提并论 ， 


经 常 在 网 站 上 ee 这 样 让 


E | 
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3. 上 传 图 片 的 技巧 


从 字面 上 理解 ， 好 像 上 传 图 片 十 分 简单 ， 实 际 上 不 是 ， 上 传 图 片 通常 会 有 两 种 情况 ， 
一 种 情况 下 是 网 速 慢 ， 只 能 上 传 少量 的 图 片 ， 一 种 是 网 速 还 可 以 ， 需 要 快速 上 传 多 张 图 片 。 
在 面 对 这 样 的 问题 时 ， 作 为 程序 的 开发 者 ， 一 定 要 充分 考虑 到 用 户 的 环境 ， 一 般 的 开发 者 
只 开发 一 种 功能 ， 只 允许 用 户 一 次 性 传 几 张 图 片 的 方法 ， 这 种 方法 是 十 分 常见 的 ， 在 刚 开 
始 的 系统 时 ， 我 们 也 是 采用 的 这 种 方法 ， 假 设 一 次 能 传 5 张 图 片 ， 我 有 30 张 图 片 ， 我 需要 
传 6 次 ， 要 单 击 许多 次 按钮 ， 这 对 于 使 用 者 ， 肯 定 是 有 些 烦 躁 ， 但 是 你 试想 一 下 ， 面 对 这 
样 的 用 户 ， 单 击 浏览 按钮 ,一 下 能 选 30 张 ， 然 后 一 张 一 张 的 上 传 ， 是 不 是 会 简单 得 多 ， 在 本 
系统 的 开发 过 程 中 ， 根 据 不 同 网 速 和 习惯 ， 提 供 了 上 述 两 种 上 传 方式 。 


4. 相册 管理 很 有 必要 


对 于 未 开发 过 相册 的 开发 者 ， 面 对 着 成 干 上 万 的 图 片 ， 是 不 会 管理 的 ， 开 发 者 是 很 难 
呈现 给 用 户 不 同 精彩 的 图 片 的 。 在 开发 的 过 程 中 ， 开 发 者 一 定 要 提示 用 户 分 好 类 ， 系 统 要 
获取 到 图 片 的 上 传 时 间 ， 图 片 的 点 击 率 ， 还 有 站 长 推荐 图 片 ， 只 有 这 样 ， 用 户 才能 方便 地 
将 相册 里 的 图 片 以 不 同 的 方式 展现 给 浏览 者 ， 开 发 者 可 以 根据 点 击 率 排 图 片 ， 开 发 者 也 可 
根据 时 间 的 倒序 排序 ， 这 样 可 以 完美 地 展示 相册 里 的 图 片 。 在 展示 图 片 的 过 程 ， 并 不 是 把 
所 有 图 片 展示 出 来 ， 毕 竞 网 页 的 窗口 有 限 ， 只 能 展示 一 些 浏览 者 关注 的 图 片 就 可 以 了 。 
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每 当 过 节 的 时 候 ， 尤 其 是 中 国 的 传统 节日 春节 ， 每 个 
人 都 有 许多 寄托 ， 希 望 新 的 一 年 会 越 来 越 好 ， 也 会 祝福 朋 
7 友 、 祝 福 亲 人 。 通 常 庙 里 会 有 许愿 树 ， 在 网 络 上 ， 也 可 以 
| 虚拟 许愿 ， 寄 托 祝 福 。 AREP, 我们 将 利用 PHP 技术 开 
发 一 个 许愿 墙 ， 从 而 进一步 加 深 对 PHP 技术 的 理解 。 
本 章 将 详细 讲解 许愿 墙 的 构成 与 特性 、 后 台数 据 库 的 
建立 与 维护 以 及 前 台 程序 的 开发 ， 为 以 后 的 学 习 打下 坚实 
的 基础 。 


V 深入 体验 PHP 项 目 开 发 


4.4 又 是 新 年 到 


小 时 候 ， 特 爱 过 春节 ， 因 为 过 春节 ， 有 新 衣服 、 新 鞋子 。 长 大 了 ， 物 质 生活 丰富 了 ， 
对 春节 逐渐 看 淡 了 ， 但 是 对 亲人 朋友 的 祝福 依然 没有 变 。 在 大 学 的 这 些 年 ， 网 络 逐 渐 走 入 
我 们 的 生活 ， 网 络 许愿 逐渐 成 了 一 种 时 尚 。 告 别 学 校生 活 后 ， 我 顺利 进入 了 一 家 网 络 公司 。 
在 公司 内 我 做 了 很 多 大 大 小 小 的 项 目 ， 但 是 对 许愿 墙 这 个 项 目 至 今 难以 忘怀 ， 因 为 它 给 了 
我 不 少 温 声 的 回忆 。 


4.1.1 项 目 来 源 
|Omorg0850,8 —— 


今天 ， 我 和 其 他 几 位 同事 被 叫 到 了 经 理 办公 室 。 我 们 几 个 人 中 既 有 老 员 工 又 有 新 来 的 
试用 期 人 员 ， 经 理 安排 给 我 们 一 个 新 项 目 一 一 新 春 许愿 墙 ， 并 且 要 求 我 们 务必 在 春节 之 前 
完成 ， 因 为 客户 在 春节 期 间 将 使 用 这 个 系统 传递 春节 祝福 。 

第 一 次 被 公司 领导 分 配 任务 ， 身 感 压力 重重 ， 不 过 我 相信 我 能 完成 。 


4.1.2. 组 建 团队 


虽然 项 目 不 大 ， 但 这 是 我 们 项 目 小 组 的 第 一 个 项 目 ， 我 们 必须 团结 一 致 ， 完 成 这 个 任 
务 ， 我 们 团队 成 员 如 下 。 

同事 A: 

他 是 浙江 传媒 学 院 来 实习 的 学 生 ， 对 计算 机 程序 懂 一 点 ， 但 不 是 十 分 擅长 ， 不 过 对 
Photoshop. Flash 等 软件 掌握 得 十 分 熟练 。 项 目的 核心 编码 其 不 能 胜任 ， 但 其 策划 经 验 是 最 


好 的 。 

任务 : 负责 项 目 规划 ， 撰 写 系统 设计 规划 书 和 美工 。 

同事 B: 

其 父母 是 做 生意 的 ， 最 大 的 特点 是 有 钱 。 从 小 酷爱 编程 ， 在 C 语言 和 数据 库 领 域 有 颇 
RAJE. 

任务 : 负责 需求 分 析 和 数据 库 设 计 。 

同事 C: 


一 个 运动 狂人 ， 喜 欢 惊险 刺激 的 户外 运动 ， 对 人 十 分 热情 ， 什 么 事情 都 喜欢 较真 ， 特 
别 是 对 感情 ， 有 点 像 电影 《不 能 说 的 秘密 》 中 的 叶 湘 伦 。 

任务 : 负责 前 台 设计 。 

当然 还 有 我 ， 负 责 系统 整体 框架 设计 及 后 台 设计 ， 并 协调 项 目 中 各 个 模块 的 进展 。 

具体 职能 结构 如 图 4-1 所 示 。 
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4-1 职能 结构 图 


整个 项 目的 具体 操作 流程 是 ， 项 目 规划 一 数据 库 设 计 一 框架 设计 一 许愿 信息 、 后 台 
管理 。 

4.1.3 小 会 议 
RAW 

我 们 四 个 新 成 员 在 会 议 室 召 开 了 一 个 会 议 ， 讨 论 了 一 下 这 个 项 目 该 从 哪 着 手 ， 如 何在 
短 时 间 内 完成 这 个 项 目 。 在 会 议 上 ， 大 家 踊跃 发 言 ， 说 出 了 自己 的 想法 。 

最 后 我 做 了 一 个 简单 的 总 结 : “新 春 许愿 详实 际 是 留言 敌 的 另 一 种 呈现 方式 ， 其 核心 
技术 在 前 台 ， 如 何 形象 地 将 网 络 许愿 寺 和 现实 的 许愿 墙 结合 起 来 才 是 王道 ， 不 需要 把 许愿 
墙 弄 得 那么 复杂 ， 也 不 需要 涉及 很 多 技术 ， 关 键 是 我 们 要 把 许愿 墙 弄 得 漂亮 、 实 用 。” 我 
的 观点 大 家 一 致 赞 同 。 会 议 安排 同事 A 尽快 作出 规划 书 ， 后 续 工作 将 以 规划 书 为 基础 进行 
扩展 。 


4.2. 系统 概述 和 总 体 设 计 
ea. wn 


会 议 结束 之 后 , 我 就 开始 监督 整个 项 目的 进展 了 , 没 想到 取得 了 不 错 的 效果 。 同事 A 
在 我 的 监督 下 ， 很 快 作出 了 项 目 规划 书 。 整 个 规划 书 分 为 以 下 两 个 部 分 : 

OQ Aka 

口 、 系 统 运行 流程 
4.2.1 系统 需求 分 析 

许愿 墙 是 针对 浏览 者 许愿 留言 的 地 方 ， 其 具体 功能 如 下 。 
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深入 体验 PHP 项 目 开 发 


s 4 


1. 随机 展示 许愿 纸 条 


呈现 给 用 户 的 纸 条 要 可 以 随处 移动 ， 就 像 墙 上 贴 的 纸 条 一 样 ， 用 户 可 以 在 众多 纸 条 中 
寻找 到 自己 的 纸 条 ， 用 户 还 可 以 关闭 一 些 纸 条 。 


2. 添加 纸 条 
添加 许愿 纸 条 是 本 系统 的 核心 。 
后 台 管理 


后 台 管 理 是 指 管理 人 员 管 理 所 有 纸 条 的 工具 ， 用 户 可 以 根据 需要 删除 不 需要 的 纸 条 。 
整个 项 目 模块 如 图 4-2 所 示 。 


上 


图 4-2 许愿 墙 功能 模块 


EEEE] 


4.2.2 系统 运行 流程 


运行 系统 后 ， 将 进入 系统 管理 首页 ， 使 用 admin 用 户 登 录 后 ， 用 户 可 以 对 其 许愿 纸 条 
进行 管理 ， 如 图 4-3 所 示 。 
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仅仅 耗 时 一 天 ， 同 事 A 的 系统 规划 工作 即 大功 告 成 。 有 了 这 个 规划 书 ， 以 后 的 工作 就 
有 目的 性 了 。 接 下 来 ， 需 要 同事 B 出 马 来 完 成 数据 库 设 计 工 作 。 


4.3 ”系统 概述 和 总 体 设计 
7 有 99, 的 


昨天 ,同事 A 完成 了 系统 规划 阶段 的 工作 ， 这样 整 个 项 目 第 一 阶段 的 工作 全 部 结束 了 。 
从 今天 开始 ,将 由 同事 B 来 完成 需求 分 析 和 数据 库 设计 的 工作 。 此 阶段 的 工作 也 十 分 重要 ， 
后 面 的 编码 工作 和 数据 库 设计 工作 都 是 基于 本 阶段 的 ， 所 以 需要 他 仔细 加 认真 。 


4.3.1 数据 库 设计 


这 个 数据 库 是 简单 的 ， 只 需要 建立 一 张 表 用 来 管理 许愿 墙纸 条 的 留言 即 可 ， 下 面 将 这 
张 表 命 名 为 plugin wish, dé 4-1 所 示 。 


表 4-1 plugin_wish 表 


字段 am 整理 x Null RU 9^ 
dd int(8) Ej auto_increment 
name varchar(255) latini swedish ci E3 
content ^ varchar(255) latin! swedish ci E3 
bg id inyint(2) 否 1 
Sign id tinyint(2) 否 1 
ip varchar(15) latint_swedish_ci 否 0000 
add time datetime Æ — 0000-00-00 00:00:00 


43.2 数据库 配置 信息 


建立 数据 库 后 ， 编 写 用 户 许愿 程序 接口 ， 让 程序 员 更 好 地 调用 该 程序 ， 下 面 通过 一 段 
代码 (function.php) 来 进行 讲解 ， 具 体 如 下 : 


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"» 
<html xmlns-"http://www.w3.0rg/1999/xhtml"» 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
</head> 
<body> 
</body> 
«/html» 
«?php 
error reporting( E ERROR | E PARSE ); 
if ( function exists( 'date default timezone set' ) ) 
date default timezone set( 'PRC' ); 
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include( 'database.inc.php' );// 调 入 网 站 配置 信息 
SDB = new MySQL(); 
THHHRHHEHEEHHHHEHHRHEHHEHEHHHBRHHE 
// 数据 库 主机 

$DB->serverName = 'localhost'; 
// 数据 库 名 

$DB-»dbName = 'wish'; 

// 数据 库 用 户 名 

$DB-»dbUsername = 'root'; 

// 数据 库 密码 

S$DB-»dbPassword = '1234'; 

// 管理 页 面 名 

SmanagePage = 'admin.php'; 
$DB-»admin ="'admin';// 登 录用 户 
$DB->password='admin';// 登 录 密码 
$DB->website =' 新 年 到 了 ， 许 个 愿 吧 ';// 网 站 title 
THRHHHHEEHHRHEEHHHRHHREHEEHRE E ERR BE 
$DB-»Connect () ; // 连 接 数据 库 
$DB->SelectDB () ; // 选 择 数据 

if ( get magic quotes gpc() ) 

t 


StripslashesArray( $ POST ); 
StripslashesArray( $ GET ); 
StripslashesArray( $ COOKIE ); 


) 
// 添 加 许愿 条 
function AddWish( $name, $content, $bgID, $signID, $ip ) 
t 
global $DB; 
$sql = "INSERT INTO plugin wish SET 
name-'($name]',content-'($content)',bg id-'($bgID)',sign id-'($signID]', 
ip-'($ip)',add time-NOW()"; 
if ( $DB-»Update( $sql ) ) 
return true; 
else 
return false; 


| 

// 获 得 许愿 信息 

function GetWishes( $start = 0, $limit = 80 ) 

{ 
global $DB; 
$sql = "SELECT * FROM plugin wish ORDER BY ID DESC LIMIT {$start}, ($1imit)"; 
return $DB-»5FM( $sql ); 


5 

// 删 除 许愿 信息 

function DeleteWish( $str ) 

{ 
global $DB; 
$sql = "DELETE FROM plugin wish WHERE id IN({$str})"; 
return $DB->FM( $sql ); 


} 
// 搜 索 许愿 信息 
function SearchWishes( Sname ) 
t 
global $DB; 
$name = str replace( '-', '', addslashes( $name ) ); 


e - 
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$sql = "SELECT * FROM plugin wish WHERE name=" {$name}' ORDER BY ID DESC 
LIMIT 0,80"; 
return $DB-»5FM( $sql ); 


5 
// 获 得 连接 信息 
function GetCount () 
t 
global $DB; 
$sql = "SELECT count(*) as total FROM plugin wish"; 
$result = $DB-»FO( $sql ); 
return $result['total']; 
H 
function StripSlashesArray( & $array ) // 斜 杠 带 
t 
while ( list( $key, $var ) = each( $array ) )/ 
t 
if ( $key != 'argc' && $key != 'argv' && ( strtoupper( $key ) != $key 
II '' . intval( $key ) == "$key" ) ) 
t 
if ( is string( $var ) ) 
$array[$key] = stripslashes( $var );// 斜 杠 
if ( is array( $var ) ) 
$array[$key] = StripslashesArray( $var ); 
$ 
} 
return $array;// 返 回 数组 数据 


} 
// 获 得 IP 地 址 
function GetIP() 
t 
if ( $ SERVER['HTTP CLIENT IP'] ) 
return $ SERVER['HTTP CLIENT _IP'];// 返 回 服务 器 IP 地 址 
elseif ( $ SERVER['HTTP X FORWARDED FOR'] ) 
return $ SERVER['HTTP X FORWARDED _FOR'];// 返 回 服务 器 地 址 
else 
return $ SERVER['REMOTE ADDR'];// 返 回 远 程 信息 


) 
// 清 除 页 面 缓存 信息 
function CleanHtmlTags( $content ) // 清 除 网 页 标签 
t 
$content = htmlspecialchars( $content ); 
$content = str replace( 'Mn', '«br />', $content ); 
$content = str replace( ' ', '&nbsp;&nbsp;' , $content ); 
return str replace( '\t', '&nbsp;&nbsp; &nbsp;&nbsp;', $content ); 


5 

// 多 个 页 面 的 处 理 

function MultiPage( $total, $onePage, $page ) 

t 
$totalPage = ceil( $total / $onePage ); 
$linkArray = explode( "page-", $ SERVER['QUERY STRING'] ); 
$linkArg = $linkAarray[0]; 


if ( $linkArg--'' ) 
$url = $ SERVER['PHP SELF'] . "?"; 
else 
i 
$linkArg = substr( $linkArg, -1 ) == "&" ? $linkArg : $linkArg . '&'; 


——— ——————————Á—————————————— > 
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$url = $ SERVER['PHP SELF'] . '?' . $linkArg; 
4 


!$totalPage && $totalPage = 1; 
( $page > $totalPage ) && $page = 1; 
!$page && $page = 1; 


$mid = floor( 10 / 2 );// 取 其 中 央 的 值 
$last = ( 10 - 1 ); 

$minPage = ( $page - $mid ) < 1 ? 1 : $page - $mid; 
$maxPage = $minPage + $last; 

if ( $maxPage > $totalPage ) // 获 取 最 大 页 面 

{ 


$maxPage = $totalPage; 
$minPage = $maxPage - $1ast; 
$minPage = $minPage < 1 ? 1 : $minPage; 


) 


for ( $i = $minPage; $i <= $maxPage; $i++ ) 
t 
if ( $i == $page ) 
SnumPageBar .= "<span class=\"page on\">[$i]</span>"; 
else 
$numPageBar .= "<a href-V"($url)page-$iV'"»[$i]«/a»"; // S d Ji 


) 


if ( $page != 1) 
$firstPageBar = "<a href=\"{$url}page=1\" title=\" 第 一 页 \"> 第 一 页 </a> 
";// 第 一 个 页 面 


if ( $page > 1 ) 
{ 
$prePage = $page - 1; 
$prePageBar = "<a href=\"{$url}page=$prePage\" title=\" 上 一 页 \"> 上 
一 页 </a> ";// 页 码 前 后 级 
} 


if ( $page < $totalPage ) 
{ 
SnextPage = $page + 1; 
$nextPageBar = " «a href=\"{$url}page=$nextPage\" title=\" 下 一 页 \" 
F—3i«/a»";// A 
} 


if ( $page != $totalPage ) 
$lastPageBar = " «a href-V"($url]page-$totalPageV" title=\" 最 后 一 页 
\ "> 最 后 一 页 </a>";// 最 后 一 个 页 面 


return $firstPageBar .  $prePageBar .  $numPageBar .  $nextPageBar 
$lastPageBar; // 返 回 到 需要 的 页 面 


} 
?» 
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4.3.3 ”建立 一 个 数据 库 类 


这 个 数据 库 类 是 整个 系统 调用 的 核心 ， 它 提供 了 许多 功能 供 浏览 者 使 用 ， 下 了 
段 代码 进行 数据 库 类 的 讲解 ， 其 代码 如 下 : 


<?php 
class MYSQL 
{ 


var $serverName 三 ，"';// 服 务 器 地 址 
var $admin 
var $password 


var $dbName = "7// 数 据 库 名 称 


var $dbUsername = "7// 后 台 管理 用 户 名 
var $dbPassword = "7// 后 台 管理 密码 
var $usePconnect = 0;// 数 据 库 是 否 永 久 连 接 
var $website ='! 7// 网 站 站 点 地 址 

var $id = 0;//id S 

var $linkId = 07// 连 接 id 号 
var $queryId = 07 

var $queryCount = 07 

Var $result; 

var $record - array(); 


var $rows; 
var $affectedRows - 0; 
var S$insertId; 
var $errno; 
var $error; 
var $queryLog - array(); 
function GetErrDesc () // 获 取 错 误 的 信息 
{ 
$this->error = @mysql error( $this-»linkld ); 
return $this->error; 
) 
function GetErrNo () // 获 取 错 误 的 代码 信息 
{ 
$this-»errno = @mysql errno( $this-»linkId ); 
return $this-»errno; 
) 
function Connect () 
t 
if ( $this-»usePconnect == 1 )// 用 户 永 久 连 接 
{ 
if ( !$this->linkId = @mysql pconnect( $this->serverName, 
$this->dbUsername, $this->dbPassword ) ) 
Sthis->Halt( 'Connect faild!' ); 
} 
else 
t 
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所 通过 一 


if ( !$this->linkId = @mysql connect( $this->serverName, $this->dbUsername, 


$this-»dbPassword ) ) 
$this-»Halt( 'Connect faild!' ); 
H 
return $this-»linkId; 
H 
function SelectDB () // 选 择 数据 库 


àd 


> 


V 
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if ( !mysql select db( $this-»dbName ) ) 
$this-»Halt( 'Connect faild!' );// 停 止 信息 


// 处 理 疑 问 信息 
function Query( $querystr ) 


$this-»result = mysql query( $queryStr, $this->linkId ); 
if ( !$this-»result ) 

$this-»Halt( 'Invalid SQL: ' . $querystr ); 
return $this-»result; 


// 更 新 信息 
function Update( $querystr ) 
t 
Sthis-»Query( $queryStr ); 
return $this-»AffectedRows(); 


) 
// 取 得 信息 
function FetchArray( $queryId, $fetchType = 'assoc' ) 
t 
if ( empty( $queryId ) ) 
$this-»Halt( 'Invalid query id:' . $queryId ); 
if ( $fetchType = 'assoc' ) 
$this-»record - mysql fetch assoc( $queryId ); 
else 
$this-»record - mysql fetch array( $queryId ); 
return $this-»record; 
) 
function FetchRow( $queryId ) // 取 得 行 信息 
{ 
if ( empty( $queryId ) ) 
$this-»Halt( 'Invalid query id:' . $queryId ); 
$this-»record = mysql fetch row( $queryId ); 
return $this-»record; 
) 
function Fetchone( $query, $field = '' )// 取 一 条 信息 
t 
if ( empty( $query ) ) 
$this-»Halt( 'Invalid query id:' . $query ); 
$this-»result = $this-»Query( $query ); 
$this-»record = $this-»FetchArray( $this-»result ); 
if ($field !— "^" 
return $this-»record[$field]; 
else 
return $this-»record; 
} 
function FetchAll( $query, $field = '' )// 取 全 部 信息 
if ( empty( $query ) ) 
Sthis->Halt( 'Invalid query id:' . $query ); 
$this-»result = $this-»Query( $query ); 
if ( $field t= '' ) 
ii 
while ( $this-»record = $this-»FetchArray( $this-»result ) ) 
$result[] = $this-»record[$field]; 
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while ( $this->record = $this->FetchArray( $this-»result ) ) 
$result[] = $this->record; 
H 
return $result; 
) 
function NumRows( $queryId ) // 获 取 行 信息 
t 
if ( empty( $queryId ) ) 
$this-»Halt( 'Invalid query id:' . $queryId ); 
$this-»rows = mysql num rows( $queryId ); 
return $this-»rows; 
) 
function AffectedRows () // 查 找 有 关联 的 数据 


t 
$this-»AffectedRows = mysql affected rows( $this-»linkId ); 


return $this-»AffectedRows; 
) 
function FreeResult( $query ) // 获 取 的 结果 为 空 
t 
if ( !mysql free result( $query ) ) 
$this-»Halt( 'Fail to mysql free result' ); 
) 
function InsertId()// 插 入 信息 
t 
$this-»insertId - mysql insert id(); 
if ( !$this-»insertIlid ) 
$this-»Halt( 'Fail to get mysql insert id' ); 
return $this-»insertId; 
) 
function Close() // 关 闭 数据 库 
{ 
Gmysgl close( $this-»linkId ); 
) 
function Halt( $msg )// 停 止 运行 c 
{ 
$message = "<html>\n<head>\n";// 头 部 信息 
$message -= "<meta content=\"text/html; charset=utf-8\" 
http-equiv=\"Content-Type\">\n";// 字 符 集 
$message .= "<style type=\"text/css\">\n";//CSS 样式 设置 
$message .= "body,td,p,pre (font-family : Verdana, 
Arial;font-size : 14px;}\n";// 信 息 大 小 
$message .= "«/style»Wn";//CSS 结束 
$message .= "</head>\n";// 头 部 信息 结束 
$message .= "<body>\n";// 网 页 内 容 开 始 


$content "<p>MYSQL Database Error!!!«/p»«pre»«b»' 
. htmlspecialchars( $msg ) . "</b></pre>\n";// 数 据 库 错误 

$content .= '«b»MySQL error description</b>: 

' . $this-»GetErrDesc() ."\n<br>";// 数 据 库 描写 

$content .= '«b»MySQL error number</b>: 

' . $this-»GetErrNo() ."\n<br>";// 数 据 库 错误 

$content .= '<b>Date</b>: ' . date( 'Y-m-d @ H:i' ) 

. "Ancbr»"; // HJ 

$content .= '«b»Script«/b»: 

http://' . $ SERVER['HTTP HOST'] . getenv( 'REQUEST URI' ) 

. "\n<br><br>";// 网 页 地 址 

Smessage .= $content;// 内 容 

$message .= "</body>\n</html>"; 


— ———Ó—— OO PISTE HERE P PECTUS » 
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echo $message;// 显 示 网 页 信息 


exit; 
} 
function NR( $queryId ) // 调 制 行 信息 
{ 

return $this->NumRows( $queryId ); 
function FM( $sql, $field = '' )// 调 制 全 部 信息 
{ 

return $this-»FetchAll( $sql, $field ); 
) 


function FA( $queryId, $fetchType = 'assoc' ) 


{ 
return $this-»FetchArray( $queryId, $fetchType ); 
) 
function FO( $query, $field = '' )// 文 件 
t 
return $this-»FetchOne( $query, $field ); 
) 
function QY( $querystr ) 
it 
return $this-»Query( $querystr ); 
) 
function AR() { 
return $this->AffectedRows(); 
) 


} 
?> 


Bonanno, WA. ERA aK 

数据 库 设计 就 像 一 口水 井 ， 里 面 装 满 了 水 ， 开 发 者 需要 将 水 进行 处 理 ， 以 符合 饮水 者 
的 要 求 ， 然 后 通过 各 种 快捷 的 管道 输送 给 对 方 。 在 设计 数据 库 时 ， 设 想 得 越 多 ， 表 结构 越 
合理 ， 开 发 程序 将 会 变 得 越 方便 、 越 简单 。 在 开发 程序 时 ， 需 要 对 各 个 字段 名 称 进一步 细 
化 ， 尤 其 在 数据 库 表 字段 、 数 据 库 配置 信息 等 ， 这 样 可 以 让 团队 其 他 成 员 快速 开发 、 快 速 
修改 。 总 结 完毕 之 后 ， 我 决定 早点 休息 ， 为 接 下 来 的 前 台 设 计 工作 做 准备 。 


44 前 台 设 计 


EXE 
过 去 的 三 天 ， 同 事 B 完成 了 需求 分 析 和 数据 库 设计 阶段 的 工作 。 有 了 上 述 资 料 ， 后 面 
的 工作 就 轻松 多 了 。 今 天 ， 整 个 项 目 进入 到 前 台 设 计 阶 段 。 此 阶段 工作 由 同事 C 来 完成 。 


4.4.1 首页 设计 


首页 是 给 浏览 者 的 第 一 印象 ， 至 关 重 要 ， 它 会 把 最 重要 的 东西 展示 给 浏览 者 ， 如 图 4-4 
所 示 为 许愿 墙 首页 。 
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图 4-4 许愿 墙 首页 


下 面 通过 一 段 代 码 (index.php) 进 行 讲解 ， 具 体 如 下 : 


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtml11/DTD/xhtmll-transitional.dtd"» 
<html xmlns-"http://www.w3.0rg/1999/xhtml"» 


<head> 

<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 

</head> 

<body> 

</body> 

</html> 

<?php 

include ( 'function.php' );// 插 入 网 页 

// 控 制 页 码 

if ( !isset( $ GET['page'] ) || empty( $ GET['page'] ) 
|| !is numeric( $ GET['page'] ) || $ GET['page'] < 1 ) 

$ GET['page'] = 1; 
erse 


$ GET['page'] = intval( $ GET['page'] ); 


$countAll = GetCount () ;// 统 计 
if ( $ POST['search'] ) 
$newEightyArray = SearchWishes( $ POST['nickname'] );// 新 的 数组 
else 
$newEightyArray = GetWishes( ( $ GET['page'] - 1 ) * 80 );// 获 得 新 的 祝愿 
krsort( $newEightyArray ); 


$pageBarHtml = MultiPage( $countAll, 80, $ GET['page'] );// 多 个 页 面 
$DB-»Close(); 

?» 

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http: //www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"» 

«html» 

«head» 

«title»«?-$DB-»website?»«/title» 

Xbgsound src-'images/newyear.mp3' loop-"-1"» 

«meta http-equiv-"Content-Type" content-"text/html; charset-utf-8" /» 
«meta content-"all" name-"robots" /» 


— —— —— ——————— HTTP PRICPETROPTRT »&9J 
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«meta name-"author" content-"Sunny V" /> 

«meta Contact" content-"tool.la(gmail.com" /> 

«meta name-"Copyright" content-"j$" /> 

«meta name-"description" content=" 许 愿 墙 -美好 人 生 从 你 我 开始 " /> 
«meta content=" 许 愿 ,许愿 墙 , 在 线 许愿 ,许愿 程序 ”name="keywords" /> 
«link rel="stylesheet" href-"css/style.css" type="text/css"> 
«link rel="stylesheet" href-"css/default.css" type="text/css"> 
«style type="text/css"> 


SE 
body ( 
background-image: url (images/bg.jpg):; 
H 
--» 
«/style» 
<SCRIPT language-"JavaScriptl.2"» 
// 判 断 表单 是 否 符合 要 求 


var Oobj=' '// 目 标 文件 
var index-10000; //z-index; //*&5l 
document.onmouseup-onMouseUp 
document .onmousemove-onMouseMove 
function onMouseDown (Object){// 鼠 标 控制 
Obj=Object .id 
document.all (Obj) .setCapture () 
pX-event.x-document.all(0Obj).style.pixelLeft; 
pY-event.y-document.all(0Obj).style.pixelTop; 
) 
function onMouseMove () {// 鼠 标 移动 控制 
if(0bj!-'"')( 
document.all(Obj).style.left-event.x-pX; 
document.all(0bj).style.top-event.y-pY; 
) 
) 
function onMouseUp () {// 单 击 鼠 标 控制 
if(0bj!-'')( 
document.all(Obj).releaseCapture(); 
Obj-''; 


} 


function onFocus (obj) {// 聚 焦 事件 
if(obj.style.zIndex!-index) ( 
index = index + 2; 
var idx = index; 
obj.style.zIndex-idx; 


) 


function onRemove () {// 移 动 事件 
if (event)( 
10bj = event.srcElement ; 
n-0; 
while (10bj && n«2) ( 
10bj = 10bj.parentElement ; 
if(10bj.tagName--"DIV") n++; 


) 


} 
var id-10bj.id 
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document .getElementById (id) .removeNode (true); 
} 


function showLogin(n) {// 显 示 登 录 信息 
var formAry = new Array ("formOne","formTwo") 
var Obj = getObject (formAry[n]) 
if (Obj.style.display == "none") ( 
Obj.style.display - "" 
) 
else 
t 
Obj.style.display = "none" 
u 

J 


function getObject (objectId) {// 获 得 目标 
if(document.getElementById && document.getElementById(objectId)) ( 
// w3c 文档 类 型 
return document.getElementById (objectId); 
) else if (document.all && document.all(objectId)) ( 
// MSIE 4 文档 类 型 
return document.all(objectId); 
) else if (document.layers && document.layers[objectId]) ( 
return document.layers [objectId];// 返 回 公开 文件 
) else ( 
return false; 
5 
) 


function chkFM(obj) {// 检 查 文件 
alert (obj.nickname.value); 
if(obj.nickname.value == "") ( 
alert ("\n\n\n 请 输入 需要 寻找 人 的 署名 ! Nn Nn") ; 
obj.nickname.focus(); 
return false; 
) 
return false; 
H 
</SCRIPT> 
</head> 
<body> 


<div id="content"> 
<div id="banner"> 
<p>&nbsp;</p> 
</div> 
<p> 
<?php include( 'nav.php' ); ?> 
</p> 
«div id="bar"> 
<div class="btn"><a href="#"><img src="images/btn search.gif" border="0" 
onclick-"showLogin(0)" /></a></div> 
<div class="btn"><a href="new.php"><img src="images/btn paste.gif" 
border="0"></a></div> 
<!-- 找 回 纸 条 弹出 菜单 --> 
«div class-"form" id-"formOne" style-"display:none"» 
«form name-schFMl action-"index.php" method="post" 
onsubmit-"return chkFM(this.form);"» 


————— ————Y————————————————— O >u 
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«input type="hidden" name-"search" value-"1"» 
«input type-"text" value=" 输 入 用 户 署名 " name="nickname" 
class-"input" 
onclick-"javascript:this.form.nickname.value-''"/»«br /> 
将 出 现 要 找 的 纸 条 <br> 
«input type-image src-"images/submit.gif" width-"45" 
height-"19" alt-"" border-"Q" /> 
«/form» 
«/div» 
<!-- 找 回 纸 条 弹出 菜单 --> 
«span class="white"> 已 有 祝福 
<?php echo $countAll; ?> 条 ， 赶 紧 贴 上 我 的 美好 祝福 ， 送 给 你 的 朋友 吧 gnbsp; 


«img src-"images/ico smile.gif" align-"absmiddle"»«/span» 


«/div» 
«div id-"contentarea"» 
EE > 
<?php 
// 获 取 全 部 更 新 的 信息 


foreach ( $newEightyArray as $key => $val ) 
» 
<DIV onmousedown-"onFocus (this)" id-"cc«?php echo stripslashes( 
$val['id']); ?>" class-"scrip«?php echo stripslashes( $val['bg id']); ?>"> 
<TABLE border-0 cellpadding-0 cellspacing-0» 
<TR> 
<TD onmousedown-"onMouseDown (cc« 
?php echo stripslashes( $val['id'] ); ?>)" style-"CURSOR: move" > 
«div class-"shead"» 
«span onDblClick="onRemove () "title=" 双 击 关闭 纸 条 "> 第 
[«?php echo stripslashes( $val['id'] ); ?>] 条 
«?php echo $val['add time']; ?> 
<a style-"CURSOR: hand" onclick="onRemove () "title=" 关 闭 纸 条 "> 
X«/a»«/span»«/div» 
«/TD» 
«/TR» 
<TR> 
<TD style="CURSOR:default"> 
<div class="sbody"><?php echo stripslashes( $val['content'] ); ?> </div> 
<div class="sbot"><img src="images/bpic 
<?php echo stripslashes( $val['sign id'] ) + 10; ?>.gif" class="left" 
border="0"><h2><a href="#" style-"font-size:l6px;"» 
«?php echo stripslashes( $val['name'] ); ?></a></h2></div> 


«/TD» 
</TR> 
</TABLE> 
</DIV> 
<?php 
} 
2> 
和 > 
«/div» 


<a href-"new.php"»«img src-"images/btn paste big.jpg" border-"0"»«/a» 
<div id-"bar"»«center»«?php echo $pageBarHtml; ?»«/center»«/div» 
«?php include( 'footer.php' ); ?>// 底 部 文件 


«/div» 


«script type-"text/javascript"» 
var elements - document.getElementById ("contentarea").childNodes; 
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for (var i = 0; i < elements.length; i++) { 
if (elements [i] .tagName && elements[i].tagName--'DIV') { 
elements [i] .style.top = Math.ceil(350 * Math.random()) + "px" 
elements[i].style.left = Math.ceil(550 * Math.random()) + "px"; 
) 
) 
</script> 
</body> 
</html> 


4.4.2 首页 设计 涉及 的 代码 


在 首页 里 涉及 了 一 些 代码 ， 这 些 代码 并 没有 在 首页 ， 而 是 将 其 调用 到 首页 里 分 别 实现 
了 一 些 功能 ， 下 面 将 详细 讲解 。 

1. 版 权 信息 

在 首页 的 下 面 有 版 权 信 息 ， 清 楚 地 向 浏览 者 展现 了 版 权 信 息 ， 下 面 通过 一 段 代码 
(footerphp) 进 行 讲解 ， 具 体 如 下 : 


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http: //www.w3.org/TR/xhtml1/DTD/xhtmll-transitional.dtd"» 
<html xmlns-"http://www.w3.0rg/1999/xhtml"» 
«head» 
«meta http-equiv-"Content-Type" content-"text/html; charset-utf-8" /» 
«style type="text/css"> 
c 
.STYLE1 (color: $FFFF00) 
-footer ( 
color: £FFF; ) 

E 
«/style»«/head»«body» 
«center» 
«div class-"STYLEl" id-"footer detail"» 

«span class="footer"> 开 发 日 记 技术 支持 «/span»«/div» 
</center> 
</body> 
</html> 


2. 其 他 两 个 页 面 

系统 中 还 有 两 个 辅助 页 面 ， 即 nav.php 和 function.php。 其 中 用 nav.php 来 展示 顶端 信息 
页 面 ， 用 function.php 来 连接 数据 库 和 操作 数据 。 文 件 nav.php 的 代码 很 简单 ，function.php 
已 经 讲解 ， 这 里 不 再 袭 述 。nav.php 代码 的 具体 如 下 : 


«SCRIPT language-JavaScript»if (self!-top) (top.location-self.location; }</SCRIPT> 


44.3. 许愿 墙 页 面 


在 前 台 设 计 里 ， 还 有 一 个 页 面 供 浏 览 者 许愿 ， 浏 览 者 进入 这 个 页 面 即 可 向 所 选 的 人 许 
愿 ， 如 图 4-5 所 示 。 
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图 4-5 许愿 页 面 
下 面 通过 一 段 代码 (new.php) 进 行 讲解 ， 具 体 如 下 : 


<?php 
include( 'function.php' );// 调 入 网 页 
// 对 许愿 表单 信息 进行 处 理 


i£ ( $ POsTi'add'] ) 
{ 

$ POST['singnature'] = CleanHtmlTags( trim( $ POST['singnature'] ) ); 

$ POST['tagbgcolor'] = trim( $ POST['tagbgcolor'] );// 背 景 颜 色 

$ POST['messages'] = CleanHtmlTags( trim( $ POST['messages'] ) );// 信 息 

$ POST['tagbgpic'] = trim( $ POST['tagbgpic'] );// 背 景 图 片 

if ( !empty( $ POST['singnature'] ) && !empty( $ POST['tagbgcolor'] ) 
&&  !empty( $ POST['messages'] ) && | !empty( $ POST['tagbgpic'] ) 
&& is numeric($ POST['tagbgcolor'] ) && !is numeric( $ POST['tagbgpic'])) 

exit( ' 参 数 错误 !， ); 

$clientIP = GetIP(); 

AddWish( addslashes( $ POST['singnature'] ), addslashes( $ POST['messages'] ), 
addslashes( $ POST['tagbgcolor'] ), addslashes( $ POST['tagbgpic'] ), 
trim( $clientIP ) ); 

@header ( "Location:index.php" ); 

exit; 

} 
$DB-»Close(); 
?» 
«html» 
<head> 
<title> 新 春 许愿 墙 </title> 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
<link rel="stylesheet" href="css/style.css" type="text/css"> 
<link rel="stylesheet" href="css/default.css" type="text/css"> 
<style type="text/css"> 
d 
body { 
background-image: url(images/bg.jpg):; 
} 
> 
</style> 
</head> 
<body leftmargin=0 topmargin=0 marginwidth=0 marginheight=0 
bgcolor=#ffffff> 
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<div id="content"> 
<center> 
«div id-"banner"»«/div» 
<SCRIPT language-JavaScript type-"text/javascript"» 
var ie = false; //IE 设置 
function getobj (id) {// 获 得 目标 文件 
if (ie) t 
return document.all[id]; // 返 回 全 部 文件 
Welse { 
return document.getElementById (id); 
) 
) 
function setTagBColor(i) {// 设 置 标签 颜色 
color = getBColor (i) ;// 设 置 颜色 
getobj ('preview') .style.background = '' + color;// 获 得 目标 文件 
hopeFM.tagbgcolor.value = i; 
) 
function setTagBPic(i) {// 设 置 标签 背景 图 
picurl = getBPic (i);// 设 置 图 片 
getObj('tagBPic').style.background = " transparent url(\"" + picurl + 
"\") no-repeat scroll bottom left";// 设 置 颜色 
hopeFM.tagbgpic.value = i; 
} 
function getBColor(i) {// 获 得 背景 颜色 
i = (i«1 || i>8)?0:parseInt (parseInt (i)-1); 
//colorArray - new Array 


("€£FFDFFF", "4C5FFC2", "£FFE3B8", "£FFCECE", "SCEECFF", "£FFFFCC", "fES8DEFF", " 
srFOFOFO") ; // 设 置 颜色 


colorArray = new Array 


(" EFFDFFF" , "$C5FFC2" , " JFFE3B8" , "#FFCECE", " ECEECFF" , " FFFFFCC", "#E8DEFF", " 
SFOFOFO"); 
return colorArray[i];// 返 回 颜 色 
} 
function getBPic(i) {// 获 得 背景 图 片 
Es (< 
//alert (parseInt (parseInt (i)+10)); 
return "images/bpic " + parseInt (parseInt (i)+10) «".gif"; 
f; 


function textCounter(field, countfield, maxlimit) {// 文 本 计算 器 
if (field.value.length > maxlimit) 
field.value = field.value.substring(0, maxlimit); 
else 
countfield.value = maxlimit - field.value.length; 
// 文 件 目录 
viewcontent.innerHTML = field.value; 
} 
function chkFM() {// 检 查 祝福 信息 
if (hopeFM.messages.value == "") { 
alert ("\n\n\n f&ff BU I 2E? Nn Nn Nn") ; 
hopeFM.messages.focus(); 
return false; 
) 
if (hopeFM.singnature.value == "") ( 


alert ("\n\n\n 请 留 下 您 的 署名 !\n\n"); 
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hopeFM.singnature.focus(); 
return false; 
) 
alert ("提交 祝福 成 功 !" ); 
return true; 
} 
</SCRIPT> 
<div> 
<p align="center">&nbsp; </p> 
<br> 
<div id="bar"> 
<div class="btn"><a href="index.php"> 
<img src-"images/btn visit.gif" border="0"></a></div> 
«span class="white"> 新 年 到 了 ， 许 个 愿 吧 . . . . . . «/span» 
«/div» 
«TABLE 
Style-"BORDER-RIGHT: £bbbbbb lpx solid; BORDER-TOP: £bbbbbb lpx solid; 
MARGIN-TOP: 20px; MARGIN-BOTTOM: 20px; BORDER-LEFT: #bbbbbb lpx solid; 
BORDER-BOTTOM: f£bbbbbb 1px solid" 
cellSpacing-0 cellPadding-0 width=500 bgColor-4fffaee border-0» 
«tr» 
«td align-center valign-top» 


«table border-0 cellpadding-0 cellspacing-0 width-700» 

«tr» 

«td align=center valign=top> 

<FORM name=hopeFM onSubmit="return chkFM();" method="post" 
action="new.php"> 


<INPUT type=hidden value="7" name="tagbgcolor"> 
idden value="1" name="tagbgpic"> 
idden value="1153391194039" name="tm"> 
<INPUT type=hidden value="1" name="add"> 
<img src="images/spacer.gif" width=1 height=8><br> 
<table border=0 cellpadding=0 cellspacing=0 width=676 
bgcolor=#EEF1EC> 
<tr> 
<td height=26><img src="images/pic_title_left.gif" width="12" 
height="26"></td> 
<td width=652 align=center class="f14 2167 pt4"> 
<strong> 我 要 贴 祝福 纸 条 </strong></td> 
<td><img src-"images/pic title right.gif" width-"12" 
height-"26"»«/td» 
</tr> 
</table> 
<br/> 
<table border=0 cellpadding=0 cellspacing=0 width=676 > 
«tr» 
«td align=center valign=top> 
<img src="images/spacer.gif" width=1 height=10><br> 
<table border=0 cellpadding=0 cellspacing=0 width=608 
background="images/line dot.gif"> 
«Er 
«td height-1»«/td» 
«/tr»«/table» 
«img src-"images/spacer.gif" width-1 height-10»«br» 
«table border-0 cellpadding-0 cellspacing-0 width-608» 
«tr align=center valign=top> 
<td width=398> 
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«table border-0 cellpadding-0 cellspacing-0 width-398» 
cn 
«td width=110 class-f12 5050> 请 选择 纸 条 颜色 : </td> 
«td width=288> 
«a href-"javascript:setTagBColor('1');"»«img border=0 
src-"images/bcolor 11.gif" width-"25" 
height-"25"»«/a» 
&nbsp;«a href-"javascript:setTagBColor('2');"» 
«img border-0 src-"images/bcolor 12.gif" width-"25" height-"25"»«/a» 
&nbsp;«a href-"javascript:setTagBColor('3');"» 
«img border-0 src-"images/bcolor 13.gif" width-"25" height-"25"»«/a» 
&nbsp;«a href-"javascript:setTagBColor('4');"» 
<img border-0 src-"images/bcolor 14.gif" width-"25" height-"25"»«/a» 
&nbsp;«a href-"javascript:setTagBColor('5');"» 
«img border-0 src-"images/bcolor 15.gif" width-"25" height-"25"»«/a» 
&nbsp;«a href-"javascript:setTagBColor('6');"» 
«img border-0 src-"images/bcolor 16.gif" width-"25" height-"25"»«/a» 
&nbsp;«a href-"javascript:setTagBColor('7');"» 
«img border-0 src-"images/bcolor 17.gif" width-"25" height-"25"»«/a» 
&nbsp;«a href-"javascript:setTagBColor('8');"» 
«img border-0 src-"images/bcolor 18.gif" width-"25" height-"25"»«/a» 
«/td» 
</tr></table> 
<table border=0 cellpadding=0 cellspacing=0 width=398> 
<tr valign=top> 
<td width=110 class='f12 5050 pt12'> 请 选择 纸 条 图 案 : </td> 
<td width=262> 
<table border=0 cellpadding=0 cellspacing=0 width=262> 
<tr align=center> 
<td width=44 height=48> 
«a href="javascript:setTagBPic('1')" > 
<img border=0 src="images/bpic 11.gif"></a></td> 
«td width-79»«a href="javascript:setTagBPic('2');"> 
«img border-0 src-"images/bpic 12.gif"»«/a»«/td» 
«td width-54»«a href-"javascript:setTagBPic('3');"» 
«img border-0 src-"images/bpic 13.gif"»«/a»«/td» 
«td width-86»«a href-"javascript:setTagBPic('4');"» 
«img border-0 src-"images/bpic 14.gif"5«/a»«/td» 
«/tr» 
«tr align=center> 
«td width-44 height-48» 
«a href-"javascript:setTagBPic('5');" > 
«img border-0 src-"images/bpic 15.gif"»«/a»«/td» 
«td width-79»«a href-"javascript:setTagBPic('6');"» 
«img border-0 src-"images/bpic 16.gif"»«/a»«/td» 
«td width-54»«a href-"javascript:setTagBPic('7');"» 
«img border-0 src-"images/bpic 17.gif"»«/a»«/td» 
«td width-86»«a href-"javascript:setTagBPic('8');"» 
«img border-0 src-"images/bpic 18.gif"»«/a»«/td» 
«/tr» 
«tr align=center> 
«td width-44 height-48» 
«a href-"javascript:setTagBPic('9');" » 
«img border-0 src-"images/bpic 19.gif"»«/a»«/td» 
«td width-79» 
«a href-"javascript:setTagBPic('10');" » 
«img border-0 src-"images/bpic 20.gif"»«/a»«/td» 
«td width-54» 
«a href-"javascript:setTagBPic('11');" > 
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«img border-0 src-"images/bpic 21.gif"»«/a»«/td» 
«td width-86» 
«a href-"javascript:setTagBPic('12');" > 
«img border-0 src-"images/bpic 22.gif"»«/a»«/td» 
«/tr» 
</table> 
</td> 
<td width=26></td> 
</tr></table> 
</td> 
<td width=210> 
<DIV id=preview style="BACKGROUND-COLOR: #E8DEFF"> 
<table border=0 cellpadding=0 cellspacing=0 width=210> 
<tr> 
<td height=1><img src="images/line top.gif" width="210" 
height="1"></td> 
</tr></table> 
<table border=0 cellpadding=0 cellspacing=0 width=210> 
«tr» 
«td align-center valign-top» 
«img src-"images/spacer.gif" width-1 height-10»«br» 
«table border-0 cellpadding-0 cellspacing-0 width-190» 
«tr» 
«td width-183 class-f12 0078> 第 [xx] 条 
&nbsp; &nbsp; &nbsp; &nbsp; <?php echo date( 'Y-m-d H:i:s', time() ); ?> </td> 
«td width=7><a href=# target- blank»«img border-0 
src-"images/pic x.gif" width-"7" height-"7"»«/a»«/td» 
</tr></table> 
<table border=0 cellpadding=0 cellspacing=0 width=190> 
<tr> 
<td id=tagBPic style='background: 
url(images/bpic ll.gif) no-repeat bottom left; word-wrap: break-word'> 
<br><br> 
<DIV id="viewcontent" style="text-align:left"> 
许愿 墙 -美好 人 生 从 你 我 开始 ， 我 们 静 静 地 欣赏 ， 回 忆 自 己 人 生 岁 月 里 沉淀 下 来 的 点 点 滴 滴 </DIV> 
<br><br><br> 
<table border="0"><tr><td width="40"> 
«/td»«td width-"150" align=right> 
<DIV id=viewsign> 我 的 署名 </DIV></td></tr></table> 
</td> 
</tr></table> 
<img src="images/spacer.gif" width=1 height=10><br> 
</td> 
</tr> 
</table> 
<table border=0 cellpadding=0 cellspacing=0 width=210> 
<tr> 
<td><img src="images/line bottom.gif" width="210" 
height="1"></td> 
«/tr» 
«/table» 
</DIV> 
</td> 
</tr></table> 
<img src="images/spacer.gif" width=1 height=10><br> 
<table border=0 cellpadding=0 cellspacing=0 width=608 
background="images/line dot.gif"> 
<tr> 
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«td height=1></td> 

</tr></table> 

<table border=0 cellpadding=0 cellspacing=0 width=608> 

«tr» 

«td height=33 class-f12 5050> 输 入 你 的 祝福 纸 条 内 容 — ( 还 能 输入 
<INPUT style-"BORDER-TOP-WIDTH: 0px; BORDER-LEFT-WIDTH: 0px; 
BORDER-BOTTOM-WIDTH: 0px; BORDER-RIGHT-WIDTH: 0px" readonly maxLength-3 
size=3 value=92 name=freeLength> 个 字 ) 

«/td» 

«/tr»«/table» 

«table border-0 cellpadding-0 cellspacing-0 width-608» 

«tr» 

«td»«textarea cols-"90" rows-"5" style-'color:$505050; 
font-size:l2px;' align="left" onKeyDown- 
"textCounter (this.form.messages,this.form.freeLength,120);" 
onKeyUp-"textCounter (this.form.messages,this.form.freeLength, 120);" 
name-"messages" wrap="physical"> 小 爱 ， 你 还 在 想 我 吗 ? 我 祝福 你 一 切 好 ! ! 
</textarea></td> 

«/tr» 

«tr»«td height-33 class-f12 5050> 您 的 署名 : «input type-text 
name-singnature maxlength-"10" value=" 佑 恩 " 
onKeyDown="javascript:viewsign.innerHTML=this.form.singnature.value" 
onKeyUp-"javascript:viewsign.innerHTML-this.form.singnature.value"»«/td» 


«tn 
</table> 
</td> 
</tr></table> 
<table border=0 cellpadding=0 cellspacing=0 width=174> 
<tr> 
<td><input type=image src="images/pic submit.gif"></td> 
</tr> 
<tr><td height=5></td></tr></table> 
</FORM> 
</td> 
</tr></table> 
二 二 Fe end -=> 
</td> 
</tr></table> 
</div> 
<?php include( 'footer.php' ); ?> 
</center> 
</div> 
</body> 
</html> 


2007F A240, 8 , 总结 

对 于 许愿 墙 的 前 台 设 计 ， 功 能 可 以 简单 ， 但 是 给 人 的 视觉 效果 要 炫 ， 当 然 功 能 也 越 炉 
越 好 ， 这 样 就 越 容易 引起 浏览 者 的 注意 ， 其 实 程序 设计 都 十 分 简单 ， 主 要 是 首页 和 一 些 售 
喜 的 动画 。 在 这 个 许愿 程序 中 ， 这 些 做 得 比较 一 般 ， 主 要 是 初 入 职场 ， 没 有 经 验 。 总 结 完 
毕 之 后 ， 我 决定 早点 休息 ， 为 接 下 来 后 台 设计 阶段 的 工作 做 准备 。 
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45 后 台 设 计 
TE 

在 前 台 工作 进行 之 时 ， 我 也 开始 了 后 台阶 段 的 设计 和 编码 工作 。 后 台 程 序 十 分 简单 ， 
主要 是 用 来 管理 许愿 纸 条 窗口 ， 如 果 有 一 条 不 符合 国家 法 律 ， 或 者 恶意 攻击 的 纸 条 ， 管 理 
者 都 可 以 将 其 删除 。 在 综合 考虑 之 下 ， 我 规划 出 此 项 目 后 台 按 照 以 下 3 个 步骤 来 实现 ; 

口 许愿 墙 管 理 首页 

口 管理 页 

口 注销 管理 页 


4.5.1 许愿 墙 管理 首页 


若 管理 员 要 对 整个 系统 进行 管理 ， 程 序 员 必 须要 给 管理 员 一 个 登录 窗口 ， 许 愿 墙 也 不 
例外 ， 如 图 4-6 所 示 。 
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图 4-6 登录 窗口 
下 面 通过 一 段 代码 (login.php) 进 行 讲解 ， 具 体 如 下 : 


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"» 
<html xmlins-"http://www.w3.0rg/1999/xhtml"» 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
<body> 
</body> 
</html> 
<? 
include ('function.php');// 插 入 页 面 信息 
session start();// 启 动 
// 对 登录 的 管理 
if(!empty($ POST['username']))( 
if($ POST['username'] == $DB-»admin) {// 用 户 
if($ POST['password'] == $DB->password) {// 密 码 
$_SESSION['admin']=$DB->admin; 
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< 


echo "«script»alert (' 登 录 成 功 !') ;location.href='admin.php';</script>"; 
} 
else{ 
echo "<script>alert (' 密 码 错 误 !') ;</script>"; 
} 
} 
else( 
echo "«script»alert (' 用 户 名 错误 !') ; «/script»"; 
} 
} 
?» 
«style type="text/css"> 
body ( 
background-image: url(images/bg.jpg); 
} 
</style> 
«table width-"100$" height-"100$" border="0" align-"center" cellpadding-"0" 
cellspacing-"0"» 
«tr» 
«form action-"" method-"post"»«td align="center" valign-"middle"» 
«table width-"400" border-"0" align="center" cellpadding-"5" 
cellspacing-"1l" class-"tablebg"» 


«tr class-"tdbg"» 

«td colspan-"2" bgcolor-"4FFFFFF"»«div align="center"> 后 台 登 录 </div> 
«/td» 

«/tr» 


«tr class-"tdbg"» 
«td bgcolor-"£4FFFFFF"»«div align="center"> 用 户 名 </div></td> 
<td bgcolor="#FFFFFF"><div align="center"> 
<input name-"username" type-"text" id="username"> 
«/div»«/td» 
«/tr» 
«tr class-"tdbg"» 
«td bgcolor-"4FFFFFF"»«div align="center"> 密 码 </div></td> 
«td bgcolor="#FFFFFF"><div align="center"> 
<input name="password" type="password" id="password"> 
</div></td> 
«/tr» 
«tr class-"tdbg"» 
«td colspan-"2" bgcolor-"£FFFFFF"»«div align="center"> 
«input type="submit" name-"Submit" value=" 登 录 "> 

«input type-"reset" name-"Submit2" value=" 重 设 "> 
</div></td> 
«/tr» 
«tr class-"tdbg"» 

«td colspan-"2" bgcolor-"£FFFFFF"»«a href="index.php"> 返 回 许 愿 墙 </a></td> 
</tr> 
</table></td></form> 
«/tr» 
</table> 


45.2 ”管理 页 


当 用 户 凭 借 着 合法 的 身份 登录 系统 后 ， 将 会 进入 许愿 纸 条 管理 页 ， 用 户 可 以 根据 需求 
删除 一 些 不 需要 的 纸 条 ， 如 图 4-7 所 示 。 
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图 4-7 许愿 纸 条 


下 面 通过 一 段 代码 (admin.php) 讲 解 如 何 完成 这 项 功能 ， 具 体 如 下 : 


<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" > 
«html» 

<head> 

<title> 后 台 管 理 </title> 

<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
«meta nam keywords" content-""» 

«meta name-"description" content-""» 

«meta nam generator" content-""» 

«meta name-"MSSmartTagsPreventParsing" content-"TRUE"» 

«meta http-equiv-"MSThemeCompatible" content-"Yes"» 

</head> 

<body> 

<?php 

include ( 'function.php' );// 插 入 页 面 

session_start () ;// 开 始 运行 

if($ SESSION['admin'] !== $DB->admin) 

{ 


if ( $ POST['submit'] ) 
t 
if (is array( $ POST['delcheck'] ) && count( $ POST['delcheck'] ) » 0) 
ü 
$delStr - implode( ',', $ POST['delcheck'] ); 
DeleteWish( $delStr ); 


) 


if ( !isset( $ GET['page'] ) || empty( $ GET['page'] ) 
|| !is numeric( $ GET['page'] ) |I 


$ GET['page'] « 1 
$ GET['page'] 
else 
$ GET['page'] = intval( $ GET['page'] );// 获 取 变量 的 整数 值 


1 一 


1; 


$countAll = GetCount () ;// 统 计 全 部 
$newEightyArray = GetWishes( ( $ GET['page'] - 1 ) * 20 ) ;// 新 的 祝福 纸 条 
$pageBarHtml = MultiPage( $countAll, 20, $ GET['page'] ); 
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SDB-»Close(); 
?» 
<FORM METHOD-"POST" ACTION-"«?php echo $managePage; ?»"» 
<TABLE width-"98$" align="center" border-"1"» 
Sy 
foreach ( $newEightyArray as $key => $val ) 
t 
echo "<TR>"; 
echo '«TD width-"10$"»«INPUT TYPE-"checkbox" NAME-"delcheck[]" VALUE-"' . $val 


| 
echo '«TD width-"10$"»' . $val['name'] . '</TD>';// 显 示 用 户 名 
echo '«TD width-"70$"»' . $val['content'] . '</TD>';// 显 示 内 容 
echo '«TD width-"10$"»' . $val['ip'] . '«/TD»';//Mb IP 
echo '«/TR5»'; 
H 
?> 
</TABLE> 
<center><INPUT TYPE-"submit" name-"submit" value=" 批 量 删 除 "></center> 
</FORM> 
<center><?php echo '«br />' . $pageBarHtml; ?></center> 
<center><a href-"logout.php"»ilHHi«/a»«/center» 
</body> 
</html> 


4.5.3 ”注销 管理 页 


当 用 户 在 后 台 完 成 操作 后 ， 需 要 退出 管理 系统 和 管理 页 。 退 出 管理 页 的 代码 十 分 简单 ， 
下 面 通过 一 段 代码 进行 讲解 ， 其 代码 如 下 : 

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 

"http://www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"» 

<html xmlns-"http://www.w3.0rg/1999/xhtml"» 

«head» 

«meta http-equiv-"Content-Type" content-"text/html; charset-utf-8" /» 

</head> 

<body> 

</body> 

</html> 

<?php 


session start (); 


// 这 种 方法 是 将 原来 注册 的 某 个 变量 销毁 
unset($ SESSION["admin"]); 


// 这 种 方法 是 销毁 整个 Session 文件 

session destroy(); 

echo "«script»location.href-'index.php';«/script»"; 
gx 


[omorsig92 9,4 — 

后 台 设计 是 管理 前 台 的 设计 ， 后 台 程序 需要 功能 强大 一 点 ， 对 于 美工 自然 没有 前 台 
求 那 么 高 ， 因 为 管理 界面 是 针对 管理 的 ， 主 要 是 方便 管理 者 使 用 。 所 以 在 企业 招聘 时 ， 一 
般 将 前 台 设计 师 和 后 台 设计 师 分 开 招聘 。 其 实 完成 后 台 工 作 的 更 应 该 称 之 为 后 台 开 发 人 员 
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或 程序 员 。 对 上 述 两 类 人 才 的 要 求 也 不 相同 ， 对 于 前 台 设 计 人 员 来 说 ， 设 计 能 力 是 第 一 要 
Z: 而 对 于 后 人 台 设 计 人 员 来 说 ， 开 发 能 力 是 第 一 要 务 。 


4.6 测 试 


经 过 这 个 漫长 的 开发 过 程 ， 我 们 四 个 人 的 团队 总 算是 完成 了 任务 。 在 开发 期 间 总 经 理 
和 部 门 经 理 都 催 过 我 们 ， 说 要 以 一 个 专业 的 程序 员 来 要 求 我 们 。 今 天 我 们 终于 看 到 胜利 的 
曙光 了 ， 最 后 的 项 目测 试 工作 由 我 来 完成 ， 我 将 工程 命名 为 “04xuyuan”。 打 开 浏 览 器 ， 
测试 本 系统 ， 如 图 4-8 所 示 。 


图 4-8 系统 的 首页 


4.6.1 系统 运行 预览 


现在 开始 运行 测试 , 项 目 运行 后 进入 许愿 墙 主 界面 ,效果 如 图 4-9 所 示 ， 浏 览 者 可 以 根 
据 提示 在 相应 的 文本 框 中 输入 许愿 信息 。 


ma wno 05731 
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注意 : 本 项 目的 具体 代码 保存 在 附 赠 光 盘 的 “第 4 章 ” 目 录 下 ， 工 程 名 称 为 “04xuyuan”.。 
请 读者 首先 将 其 复制 到 硬盘 中 ， 去 掉 文 件 的 只 读 属性 。 


4.62 验收 


项 目 正式 交 给 了 部 门 经 理 ， 经 理 反 复 推 殴 ， 对 我 们 的 项 目 给 予 了 充分 的 肯定 ， 我 们 的 
项 目 可 以 正式 投放 运行 ， 公 司 领导 层 都 普遍 表示 不 错 。 在 后 期 维护 上 ， 我 也 安排 了 分 工 ， 
我 们 四 个 人 在 新 春 期 间 要 死 死 盯 着 这 个 系统 ， 让 浏览 者 正常 使 用 。 


4.6.3 总 结 


项 目 总 算 完成 了 ， 其 实 许愿 墙 和 留言 簿 十 分 相似 ， 只 是 在 展示 上 有 所 不 同 。 留 言 簿 可 
以 回复 相关 的 留言 ， 或 者 引用 别人 的 言语 进行 编辑 ， 而 许愿 墙 只 能 够 直接 读 取 一 段 信息 ， 
在 后 台中 和 留言 短 十 分 相似 ， 甚 至 比 留言 短 简 单 。 经 过 这 个 项 目的 经 历 ， 我 既 有 所 得 也 有 
所 失 。 在 此 将 我 的 感受 分 享 给 读者 希望 共勉。 

首先 谈 一 下 我 完成 这 个 项 目 后 的 技术 总 结 ， 主 要 有 以 下 两 点 。 

1) 对 留言 的 展示 

在 开发 的 过 程 中 要 选择 合适 的 技术 来 展示 许愿 信息 ， 许 愿 墙 的 展示 是 美观 的 ， 它 的 展 
示 要 求 要 高 于 留言 短 。 开 发 者 选择 技术 十 分 重要 ， 否 则 很 难 完全 展示 ， 最 初 准 备用 flash 动 
画展 示 留 言 信息 ， 后 来 选择 放弃 了 ， 因 为 这 样 工程 太 大 ， 最 终 用 了 新 的 Ajax 技术 ， 也 就 是 
CSS, JavaSript, XML 等 技术 的 结合 ， 制 作出 了 可 以 移动 ， 可 以 关闭 ， 可 以 随机 展示 在 指 
定 区 域 的 许愿 墙 。 

2) 签 写 许愿 纸 条 是 核心 

对 于 许愿 墙 这 样 的 程序 来 说 ， 签 写 许愿 纸 条 是 本 项 目的 核心 功能 之 一 。 在 设计 的 时 候 ， 
许愿 突出 两 个 部 分 ， 签 写 纸 条 的 人 在 签 写 完 后 ， 能 够 看 到 ， 许 愿 将 及 时 添加 的 许愿 纸 条 置 
硕 突出 显示 ， 在 开发 测试 的 时 候 ， 发 现 这 样 一 个 问题 ， 在 许愿 首页 出 现 了 两 个 一 模 一 样 的 
纸 条 ， 唯 一 不 同 的 是 许愿 信息 的 ID 号 ， 如 果 访 客 每 次 发 送 两 条 一 样 的 信息 ， 显 然 是 不 对 ， 
而 且 耗 费 资 源 ， 出 现 这 样 的 问题 ， 很 可 能 是 表单 信息 、 验 证 表单 、 数 据 库 表 或 者 SQL 语句 
出 了 问题 ， 如 果 出 现 此 类 问题 ， 可 在 这 几 个 地 方 查阅 进行 修改 。 在 开发 时 出 现 此 类 问题 ， 
主要 是 填写 表单 信息 和 验证 表单 的 时 候 ， 各 向 数据 库 提交 了 一 次 信息 ， 所 以 就 造成 了 在 数 
WEP, RID 号 不 同 ， 信 息 完全 相同 的 情况 。 

写 完 技术 总 结 之 后 ， 再 写 点 经 验 。 想 着 我 们 的 项 目 ， 整 个 项 目的 流程 是 一 个 团队 协作 
的 过 程 ， 分 工 明确 。 在 此 我 总 结 了 两 点 经 验 : 

1) 时 间 的 重要 性 ， 试 问 你 心中 有 底 吗 

客户 一 开始 就 强调 元 旦 之 前 必须 完成 ， 所 以 我 们 全 都 疯狂 加 班 抢 时 间 ， 终 于 在 元 旦 之 
前 完成 了 整个 项 目 。 其 实在 项 目 开始 之 前 ， 我 就 规划 好 了 时 间 ， 并 且 预 留 了 5 天 意外 时 间 
防止 意外 发 生 。 所 以 虽然 加 班 很 累 ， 从 外 人 看 来 我 们 忙 忙碌 碌 的 在 赶 项 目 ， 其 实 我 们 心里 
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都 有 底 ， 完 成 没有 问题 。 如 果 你 都 心中 没 底 ， 那 么 你 得 仔细 权衡 下 ， 有 没有 接 这 个 项 目的 
必要 性 ! 


2) 程序 可 扩展 性 的 重要 性 

从 项 目 规划 开始 ， 到 数据 访问 层 设计 ， 必 须 实现 程序 的 无 颖 可 扩充 功能 。 这 样 即 使 客 
户 提出 了 新 的 要 求 ， 也 不 用 去 重新 写 程序 ， 这 样 能 缩短 开发 周期 。 在 这 个 项 目 中 ， 客 户 提 
出 了 增加 查询 和 排序 的 要 求 ， 同 事 编写 的 代码 有 很 强 的 可 扩展 性 ， 所 以 基本 没 耽误 时 间 。 
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随 着 网 络 技术 日 新 月 异 的 发 展 ， 许 多 传统 模式 的 工作 

也 逐渐 开始 网 络 化 和 信息 化 。 图 书 管理 工作 也 开始 逐渐 依 

f 赖 计算 机 来 完成 ， 目 前 许多 大 型 图 书馆 有 一 整套 的 图 书 管 

理 系 统 ， 但 小 型 图 书馆 ， 大 部 分 工作 仍 需 手 工 完成 ， 这 给 
图 书 管理 者 带 来 繁重 的 工作 。 

本 章 将 详细 讲解 如 何 开发 一 套 小 型 的 图 书馆 管理 系 

统 ,并 用 它 来 解决 手工 工作 的 一 些 冶 端 , 通过 本 章 的 学 习 ， 

读者 要 将 详细 了 解 图 书馆 管理 系统 的 开发 流程 ， 这 将 为 以 

后 深入 地 学 习 数 据 库 开 发 设计 打下 坚实 的 基础 。 
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5.4 和 同事 们 聚会 
| 200235209, 8 —— 


阳春 三 月 ， 暖 风 渐 渐 吹 起 ， 冬 天 已 经 过 去 。 为 了 增进 友谊 ， 我 、 同 事 A、 同 事 C、 同 事 
D 还 有 产品 部 的 几 位 同事 相约 一 起 晚餐 ， 饭 后 到 KTV 一 展 歌喉 。 酒 意 正 浓 ， 我 们 说 了 好 多 
祝福 和 相互 激励 的 话 。 看 着 我 一 个 个 可 爱 的 同事 ， 我 很 知足 。 周 一 到 周 五 的 上 班 时 间 ， 我 
和 同事 们 朝夕 相处 ， 突 然 觉 得 自从 进入 职场 后 ， 和 同事 们 相处 的 时 间 是 最 长 的 。 项 目 中 的 
互相 合作 ， 中 午 闲暇 时 刻 的 神 侃 和 忽 您， 一 幕 幕 地 在 脑海 中 出 现 。 


5.1.1 准备 休假 
Lo-wbws39829.9 


都 说 烟花 三 月 下 扬州 ， 我 想 休假 去 一 趟 江南 。“ 江 南 好 ， 风 景 旧 曾 诺 。 日 出 江 花红 胜 
火 ， 春 来 江水 绿 如 蓝 。 能 不 忆 江 南 ?” ”想起 白居易 的 诗句 ， 更 增添 了 我 对 江南 的 神往 。 


5.1.2 ”休假 失败 


下 午 去 DP 办 公 室 申 请 休假 的 事情 。DP 建议 我 过 一 段 时 间 再 去 ， 说 今天 公司 刚 接 到 一 
个 项 目 ， 准 备 让 我 到 开发 团队 中 去 。 


5.1.3 ”新 的 项 目 


今天 是 周一 ， 每 周一 次 例 行 的 早 会 如 期 举行 。DP 宣布 接 下 来 的 一 个 月 我 们 将 要 做 一 个 
新 的 项 目 ， 做 完 之 后 给 大 家 放假 。 客 户 是 省 内 211 工程 的 重点 高 校 ， 想 让 我 们 为 其 开发 一 
个 图 书 管理 系统 ，DP 会 亲自 负责 这 个 项 目 。 


5.1.4 组 建 团 队 
CE —— 


团队 的 主要 成 员 有 以 下 几 人 。 

同事 A: 

他 来 自 江 南 水 乡 之 都 宁波 ， 在 大 学 期 间 读书 十 分 用 功 ， 大 多 数 设 计 软 件 都 学 过 。 尽 管 
都 不 精通 ， 但 其 策划 经 验 是 最 好 的 。 

任务 : 负责 项 目 规划 ， 扎 写 系统 设计 规划 书 。 
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同事 B: 

公司 的 资深 员工 之 一 ， 毕 业 后 至 今 一 直 在 本 公司 工作 ， 擅 长 数据 库 相关 的 设计 。 

任务 : 负责 需求 分 析 和 数据 库 设 计 。 

同事 C: 

一 个 美女 级 的 运动 狂人 ， 喜 欢 惊险 刺激 的 户外 运动 ， 每 天 早晨 都 会 去 操场 长 跑 ， 擅 长 
模块 设计 用 户 信息 设计 。 

任务 : 负责 设计 系统 信息 管理 模块 和 用 户 管理 模块 。 

同事 D: 

一 个 普通 城市 家 庭 的 孩子 ， 戴 一 副 眼 镜 ， 文 质 彬 彬 的 。 此 人 十 分 聪明 ， 技 术 水 平 极 高 ， 
是 公司 花 重 金 从 别 的 公司 挖 来 的 。 
任务 : 负责 图 书 借阅 模块 。 
R: 
主要 任务 : 负责 系统 测试 ， 并 协调 项 目 中 各 个 模块 的 进展 。 

另外 ， 公 司 为 了 确保 和 客户 交流 的 顺利 ， 还 安排 了 产品 部 的 同事 SEC 负责 在 我 们 开发 
团队 和 客户 之 间 进 行 沟通 。 

具体 职能 结构 如 图 5-1 所 示 。 


同事 A 信 Mem 
撰写 策划 REA 
用 户 管理 模块 
同事 B 同事 D 
数据 库 设计 图 书 借阅 模块 


5-1 职能 结构 图 
整个 项 目的 具体 操作 流程 是 : 项 目 规划 一 数据 库 设计 一 框架 设计 一 系统 信息 管理 、 用 
户 管理 、 图 书 借阅 。 
5.1.5 “小 会 议 
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今天 我 们 召开 了 一 个 动员 会 议 ， 并 为 未 来 项 目的 进展 做 了 一 个 简单 的 规划 。 我 们 一 至 
认为 : 本 项 目 包括 后 台数 据 库 的 建立 、 维 护 以 及 前 台 应 用 程序 的 开发 两 个 方面 。 数 据 库 访 
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问 技术 ， 将 每 个 数据 库 表 的 字段 和 操作 封装 到 相应 的 类 中 ， 使 应 用 程序 的 各 个 窗 体 都 能 
共享 对 表 的 操作 ， 而 不 需要 重复 编码 ;使 程序 更 加 易于 维护 ， 从 而 将 面向 对 象 的 程序 设计 
思想 成 功 应 用 于 程序 设计 中 ， 这 也 是 本 系统 的 优势 和 特色 。 

最 后 我 做 了 一 个 简单 的 总 结 : “要 开发 一 个 图 书馆 管理 系统 ， 首 先 需要 进行 系统 需求 
分 析 和 总 体 设 计 ， 分 析 系 统 的 使 用 对 象 和 用 户 需求 ， 设 计 系统 的 体系 结构 和 数据 库 表 结构 ， 
决定 使 用 的 开发 工具 和 后 台数 据 库 ， 规 划 项 目的 开发 进度 等 。” 

会 议决 定 同事 A 尽快 作出 规划 书 ， 后 续 工 作 将 以 规划 书 为 基础 进行 扩展 。 


5.2 系统 概述 和 总 体 设 计 


今天 同事 A 做 出 了 项 目 规划 书 ， 整 个 规划 书 分 为 两 个 部 分 : 
口 系统 需求 分 析 
O ”系统 运行 流程 


5.2.4. 系统 需求 分 析 


图 书馆 管理 系统 的 用 户主 要 功能 包括 基本 信息 设置 、 图 书 借 还 管理 、 系 统 信息 设置 等 
主要 模块 ， 其 具体 功能 介绍 如 下 。 

1) 基本 信息 设置 

基本 信息 设置 是 用 来 对 图 书 管理 系统 进行 一 些 常规 设置 ， 如 图 书信 息 管理 的 设置 、 专 
业 信 息 、 学 生 信 息 管理 等 。 

2) 图 书 借 还 信息 管理 

图 书 借 还 信息 管理 是 一 个 图 书馆 管理 系统 的 核心 ， 这 里 的 借 还 信息 管理 ， 可 以 根据 实 
际 情况 自己 定义 ， 如 一 个 人 可 以 借阅 两 本 、 一 本 书 的 期 限 为 30 天 等 ， 管 理 员 可 以 根据 实际 
情况 进行 设置 。 

3) 系统 信息 设置 

系统 信息 设置 是 设置 本 图 书馆 最 基本 的 信息 ， 如 这 个 图 书 管理 系统 的 名 称 是 西南 传媒 
大 学 图 书馆 管理 系统 ， 倘 车 用 户 有 和 需求， 完全 用 这 个 代码 ， 完 全 变 为 西南 传媒 大 学 戏剧 管 
理学 院 图 书 管理 系统 ， 整 个 图 书馆 的 基本 信息 都 会 发 生变 化 ， 而 不 必 重 新 花 钱 再 开发 一 个 
系统 ， 管 理 员 就 可 以 完成 这 样 的 工作 。 

根据 需求 分 析 总 结 的 用 户 需 求 设计 系统 的 体系 结构 , 如 图 5-2 所 示 。 在 体系 结构 示意 图 
中 ， 每 一 个 叶 结 点 是 一 个 最 小 的 功能 模块 ， 每 一 个 功能 模块 都 需要 针对 不 同 的 表 完 成 相同 
的 数据 库 操作 ， 即 添加 记录 、 删 除 记 录 、 查 询 记 录 、 更 新 记录 。 
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图 5-2 图 书馆 管理 系统 功能 模块 示意 图 
5.22 ”系统 运行 流程 


在 此 模拟 了 系统 的 运行 情景 : 运行 系统 后 ， 打 开 主 页 ， 如 图 5-3 所 示 , 会 先 显示 一 个 用 


户 登录 对 话 框 ， 对 用 户 的 身份 进行 认证 并 确定 用 户 的 类 型 。 如 果 需 要 对 普通 用 户 进行 管理 ， 
则 使 用 admin 用 户 登录 。 
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图 5-3 图 书 管理 系统 主页 
5.3 ”数据库 设计 


今天 同事 A 将 撰写 好 的 规划 书 交 给 了 同事 了 B。 同 事 B 将 根据 规划 书 的 需求 来 设计 数据 
库 ， 整 个 项 目 进入 第 二 阶段 。 数 据 库 设计 是 总 体 设计 中 一 个 重要 的 环节 ， 良 好 的 数据 库 设 


OE nns escudos eaha aonaran anades aoa oa akata csaa oisasd d naiin esaeas Nadansu nasasa ba saas Ed 157 | 


V 深入 体验 PHP 项 目 开 发 


计 可 以 简化 开发 过 程 ， 提 高 系统 的 性 能 ， 使 系统 功能 更 加 明确 。 一 个 好 的 数据 库 结构 其 优 
点 是 系统 处 理 速 度 快 、 占 用 空间 小 、 操 作 处 理 过 程 简单 、 数 据 容易 查找 等 。 数 据 库 结构 的 
变化 会 造成 编码 的 改动 ， 所 以 在 编码 之 前 ， 一 定 要 认真 设计 好 数据 库 ， 避 人 免 无 谓 的 返工 。 


5.3.1 数据库 结构 的 设计 


由 需求 分 析 的 规划 可 知 整个 项 目 对 象 有 11 种 信息 , 所 以 对 应 的 数据 库 也 需要 包含 这 11 
种 信息 ， 从 而 系统 需要 包含 11 个 数据 库 表 ， 分 别 是 : 
tb bookcase: 图 书 分 类 信息 表 ; 
tb bookinfo: 图 书信 息 表 ; 
tb booktype: 图 书馆 分 类 信息 ; 
tb borrow: 图 书 借阅 信息 表 ; 
tb library: 图 书馆 属性 表 ; 
tb_manager: 图 书馆 管理 员 表 ; 
tb_parameter: 参数 设置 ; 
tb publishing: 出 版 社 信息 表 ; 
tb purview: 图 书 借阅 限制 信息 表 ; 
tb_reader: 图 书 借阅 人 员 信息 表 ; 
tb readertype: 图 书 借阅 人 员 分 类 信息 表 ; 
具体 数据 库 表 的 书面 文件 如 下 。 
(1) 图 书 分 类 信息 表 (tb_bookcase)， 用 来 保存 图 书 分 类 信息 ， 表 结构 如 表 5-1 所 示 。 


R51 图 书 分 类 信息 表 
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FR 整理 ME nu 默认 额外 
id int(10) UNSIGNED Æ auto increment. 
name varchar30) 9b2312 chinese ci X NULL 
(2) 图 书信 息 表 (tb_bookinfo)， 用 来 保存 图 书信 息 ， 表 结构 如 表 5-2 所 示 。 
表 5-2 图 书信 息 表 
*& zm Et ni BU LII 

barcode 。 varchar30) gb2312 chinese ci 是 NULL 
bookname varchar70) 9b2312 chinese ci 是 nu 
typeid int(10) UNSGNED 是 NULL 
author varchar(30) gb2312 chinese di 是 NULL 
translator varchar(30) gb2312 chinese di 是 NULL 
ISBN varchar(20) gb2312 chinese ci 是 NULL 
price float(8.2) 是 NULL 
page int(10) UNSIGNED 是 NULL 
bookcase  int(10) UNSGNED 是 — NULL 

int(10) UNSIGNED 是 NULL 
inTime date 是 NULL 
operator ^ varchar30) gb2312_chinese_ci 是 NuL 
del inyint(1) 是 0 

int(11) z auto_increment 


G) 图 书馆 图 书 分 类 信息 表 (tb_booktype)， 用 来 保存 图 书馆 的 图 书 分 类 信息 ， 表 结构 如 
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表 5-3 所 示 。 
表 5-3 图 书馆 分 类 信息 
TÉ 整理 E Null RU LL 
id int(10) UNSIGNED & auto increment 
typename varchar(30) gb2312 chinese ci 是 NULL 
days int(10) UNSIGNED 是 NULL 


(4) 图 书 借阅 信息 (tb_borrow)， 用 来 保存 图 书馆 的 图 书 借阅 类 信息 ， 表 结构 如 表 5-4 
所 示 。 


表 5-4 图 书 借阅 图 书信 息 


字段 类 型 整理 Et wu RU LL 

id int(10) UNSIGNED 否 auto increment 
readerid  int(10) UNSIGNED 是 NULL 

bookid int(10) 是 NULL 

borrowTime date 是 NULL 

backTime ^ date 是 NULL 

‘operator varchar(30) gb2312_chinese_ci 是 NULL 

ifback tinyint(1) 是 0 


(5) 图 书馆 属性 表 (tb_library)， 用 来 保存 图 书馆 的 基本 信息 ， 表 结构 如 表 5-5 所 示 。 
表 5-5 图 书馆 属性 表 


字段 类 型 EJ 属性 nup 默认 额外 
id int(10). UNSIGNED Æ auto_increment 
lbraryname varchar(50) gb2312_chinese_ci 是 NULL 
curator varchar(10) gb2312_chinese_ci 是 NULL 
tel varchar(20) —gb2312 chinese ci A NULL 
address varchar(100) gb2312 chinese ci 是 NULL 
email varchar(100) gb2312_chinese_ci A NULL 
ur varchar(100) gb2312 chinese ci 是 NULL 
createDate date 是 NULL 
introduce — tex 92312 chinese ci 是 NULL 


(6) 图 书馆 管理 员 表 (tb_manager)， 用 来 保存 图 书馆 管理 人 员 的 基本 信息 ， 表 结构 如 
表 5-6 所 示 。 


表 5-6 图 书馆 管理 员 表 


TÉ EJ zm E Null 默认 额外 
id int(10) UNSIGNED € auto increment 
name varchar30) 9b2312 chinese ci 是 NULL 
pwd varchar(30) gb2312 chinese ci 是 NULL 
(7) 参数 设置 表 (tb_parameter)， 用 来 设置 借阅 参数 ， 表 结构 如 表 5-7 所 示 。 
表 5-7 参数 设置 表 
字段 ”类型 E nu RU LL 
id int(10) UNSIGNED Æ auto_increment 
cost  int(10) UNSIGNED 是 NULL 
validity | int(10) UNSIGNED 是 NULL 
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(8) 出 版 社 信 息 表 (tb_publishing)， 用 来 存储 出 版 社 信 息 ， 表 结构 如 表 5-8 所 示 。 
表 5-8 出 版 社 信息 表 


TÉ 类 型 Ett Nul UNE Ll 
ISBN varchar(20) gb2312_chinese_ci * NULL 
pubname varchar(30) gb2312 chinese ci 是 NUL 


(9) 图 书 借阅 限制 信息 表 (tb_purview)， 用 来 设置 图 书 借阅 限制 信息 ， 表 结构 如 表 5-9 
所 示 。 


表 5-9 图 书 借阅 限制 信息 表 
TB ZE ”整理 E mi BU 人 外 


id int(11) *" 0 
sysset inyint(t) 是 0 
readerset ^ tinyint(1) 是 0 
bookset tinyint(1) 是 0 
borrowback  tinynt(1) 是 0 
sysquery  tinyint(1) 是 0 


(10) 图 书 借阅 人 员 信息 表 (tb readeD， 用 来 设置 图 书 借阅 人 员 信息 ， 表 结构 如 表 5-10 


所 示 。 
表 5-10 图 书 借阅 人 员 信息 表 
TÉ 类 型 整理 Et nui 默认 额外 
id int(10) UNSIGNED 否 auto_increment 
name varchar(20) — gb2312 chinese ci 是 NULL 
Sex varchar4) ^ gb2312 chinese ci 是 NULL 
barcode varchar(30)  gb2312 chinese ci 是 NULL 
vocation 。 varchar(50) — gb2312 chinese ci 是 NULL 
birthday date 是 NULL 
paperType varchar(10) — gb2312 chinese ci 是 NULL 
paperNO 。 varchar(20) ”9b2312_chinese_ol 是 nuu 
tel varchar(20) —gb2312 chinese ci 是 NULL 
email varchar(100) 9b2312 chinese ci 是 NULL 
createDate date 是 NULL 
operator 。 varchar(30) gb2312_chinese_ci 是 nuu 
remark mediumtex ^ gb2312 chinese ci * NuL 
‘typeid int(11) 是 NuL 


(11) 图 书 借阅 人 员 分 类 信息 表 (tb readertype)， 用 来 设置 图 书 借阅 人 员 分 类 信息 ， 表 结 
构 如 表 5-11 Bras. 


表 5-11 图 书 借阅 人 员 分 类 信息 表 


FR 类 型 EJ Æ wu RU LI 

id int(10) UNSIGNED 否 auto_increment 
name varchar(50) 9b2312 chinese ci 是 nu 

number int(4) 是 NULL 


5.3.2 ”数据 库 设置 信息 
当 建 立 好 数据 库 后 ， 需 要 为 用 户 提供 一 个 统一 的 数据 库 属性 表 ， 当 需要 调用 数据 库 的 


人 人 s 


第 5 章 图 书馆 管理 系统 


时 候 只 需 直 接 调 用 这 段 代 码 即 可 ， 这 样 大 大 减少 了 代码 编写 量 。 具 体 代码 如 下 : 
«?php 
$conn-mysql connect ("localhost","root","1234") or die 


(" 数 据 库 服务 器 连接 错误 ".mysql_error ()): 
mysql select db("db library",$conn) or die 


(" 数 据 库 访问 错误 " .mysql error ()); 
mysql query("set names gb2312"); 


?> 


i, 数据 库 设 计 的 注意 事项 


至 此 ， 整 个 数据 库 设 计 完毕 ， 这 也 标志 着 整个 项 目的 第 二 阶段 的 工作 全 部 完成 了 。 此 
刻 我 深刻 体会 到 作为 一 个 完善 的 系统 ， 数 据 库 表 是 极其 繁多 的 。 在 设计 数据 库 表 时 ， 需 要 
注意 各 个 字段 的 标准 型 ， 明 确 表 与 表 之 间 的 关系 ， 不 然 会 给 开发 者 带 来 极 大 的 麻烦 。 
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刚刚 结束 数据 库 的 设计 工作 ， 我 们 整个 团队 马不停蹄 地 进入 了 第 三 阶段 的 工作 。 此 阶 
段 的 任务 是 完成 系统 首页 的 设计 ， 此 任务 是 由 同事 C 来 完成 的 。 当 她 将 规划 书 和 设计 的 数 
据 库 浏览 完毕 之 后 ， 整 个 思路 就 已 经 在 她 脑海 中 形成 了 。 


5.4.1 判断 管理 员 的 权限 


图 书馆 管理 系统 是 一 个 功能 全 面 的 Web 网 站 ， 通 过 对 网 站 的 安全 考虑 ， 需 要 十 分 清楚 
对 系统 进行 权限 的 分 配 ， 只 有 管理 员 级 别 的 超级 用 户 可 以 对 普通 人 员 的 权限 进行 管理 和 设 
置 。 在 首页 里 通过 判断 管理 员 的 权限 来 显示 该 用 户 所 操纵 的 功能 模块 , 其 代码 (navigation php) 
Wr: 


<?php 
session start () ;// 初 始 化 变量 
include ("conn/conn.php") ;// 连 接 数 据 库 文 件 
$query-mysql query ("select 
m.id,m.name,p.id,p.sysset,p.readerset,p.bookset,p.borrowback,p.sysquery 
from tb manager as m left join (select * from tb purview ) as p on m.id-p.id 
where name-'$ SESSION[admin name]'"); 
$info-mysql fetch array ($query); 
?» 
«meta http-equiv-"Content-Type" content-"text/html; charset-gb2312"» 
«script src-"JS/menu.JS"»«/script» 
«style type="text/css"> 
.admin { 

color: £$FFF; 


«/style»«div class-menuskin id-popmenu 
onmouseover-"clearhidemenu();highlightmenu (event, 'on')" 
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onmouseout-"highlightmenu (event, 'off');dynamichide (event) " 
style-"Z-index:100;position:absolute;"»«/div» 
«table width-"990" border-"0" align="center" cellpadding-"0" 
cellspacing-"0"» 
«tr» 
«td height-"115" align-"right" valign-"bottom" 
background-"Images/banner.jpg" bgcolor-"£FD9Cll"»«table width-"100$" 
border-"0" cellspacing-"0" cellpadding-"0"» 
«tr» 
«td height-"196" align="right" valign="bottom" class-"admin"» 
当前 登录 的 用 户 ; 
<?php echo $ SESSION[admin name];?» 
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; «/td» 
«/tr» 
</table></td> 
</tr> 
<tr> 
<td height="33" align="right" bgcolor="#FD9C11"><table width="100%" 
border="0" cellspacing="0" cellpadding="0"> 
<tr> 
<td width="5%"></td> 
«td width-"23$"»«script type=text/javascript> 
document.write ("<span id-'labtime' width-'120px" 
Font-Size-'9pt'»«/span»") 
setInterval("labtime.innerText-new Date().toLocaleString()",1000) 
«/script»«/td» 
«td width-"70$" align-"right"»«a href-"index.php" class="al"> 首 页 </a> 


] 
<?php if(Sinfo[sysset]--1)( ?> 

<a onmouseover-showmenu (event,sysmenu) onmouseout-delayhidemenu|() 

style-"CURSOR:hand" class="al"> 系 统 设置 </a> | 
<?php }?><?php if ($info[readerset]--1) (?» 
«a onmouseover-showmenu (event,readermenu) onmouseout-delayhidemenu() 

style-"CURSOR:hand" class="al"> 读 者 管理 </a> | «?php ) ?> 
<?php if($info [bookset]==1){ ?> 
«a href-"book.php" class="al"> 图 书 档案 管理 </a> | 
<?php )?»«?php if ($info[borrowback]--1) (?» 
«a onmouseover-showmenu (event,borrowmenu) onmouseout-delayhidemenu() 
style-"CURSOR:hand"class-"al" > 图 书 借 还 </a> | 

<?php }?><?php if ($info[sysquery]==1){ ?> 
«a onmouseover=showmenu (event, querymenu) onmouseout=delayhidemenu () 

style-"CURSOR:hand" class="al"> RAA M]</a> | <?php } ?> 
«a href-"pwd Modify.php" class="al"> 更 改口 令 </a> | <a href-"safequit.php" 
class="al"> 注 销 </a></td> 

«td width-"2$"»&nbsp;«/td» 
«/tr» 
«/table»«/td» 

«/tr» 

«/table» 
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在 本 系统 首页 ， 推 出 了 一 个 专门 区 域 来 显示 图 书 的 排行 信息 ， 并 将 排行 结果 按 借阅 数 
量 降序 排列 ， 具 体 效 果 如 图 5-4 所 示 。 
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图 5-4 图 书 排行 信息 


下 面 通过 一 段 代码 (index.php) 进 行 讲解 ， 具 体 如 下 : 


«?php 

include ("check login.php"); 

include ("conn/conn.php") ;// 连 接 数 据 库 

?> 

<html> 

<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
<head> 

<title> 学 校 图 书馆 管理 系统 </title> 

«link href-"CSS/style.css" rel="stylesheet"> 

</head> 

<table width="776" border="0" align="center" cellpadding="0" 
"0" class="tableBorder"> 


<td><?php include ("navigation.php"); ?></td> 
«/tr» 
«td bgcolor-"£FFFFFF"» 
«table width-"100$" border="0" cellspacing-"0" cellpadding-"0"» 
«tr» 
«td valign="top" bgcolor-"£FFFFFF"»«table width-"100$" height-"510" 
border-"0" 
align="center" cellpadding-"0" cellspacing-"0" bgcolor-"£4FFFFFF" 
class-"tableBorder gray"» 
«tr» 
«td align="center" valign="top" style-"padding:5px;"» 
«table width-"974" border="0" cellpadding-"0" cellspacing-"0"» 
«tr» 
«td width-"974" height-"45" valign="top"> 
«img src-"Images/main booksort l.gif" width-"964" height-"43"»«/td» 
«/tr» 
«tr» 
«td height-"68" valign="top"> 
«table width-"969" Pborder-"1" cellpadding-"0" cellspacing-"0" 
bordercolor-"£FFFFFF" bordercolordark-"£D2E3E6" 
bordercolorlight-"£FFFFFF"» 
«tr align="center"> 
«td width-"4$" height="25"> 排 名 </td> 
«td width="10%"> 图 书 条 形 码 </td> 
«td width="22g%"> 图 书 名 称 </td> 
«td wiqth="11%"> 图 书 类 型 </td> 
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«td width="9%"> 书 架 </td> 
«td wiqdth="13$%"> 出 版 社 </td> 
«td width="15%"> 作 者 </td> 
«td width="8%"> 定 价 (元 ) </td> 
«td width="8%"> 借 阅 次 数 </td></tr> 
«?php 
$sql-mysql query("select * from (select 
bookid, count (bookid) as degree from tb borrow group by bookid) as borr join 
(select b.*,c.name as bookcasename,p.pubname,t.typename from tb bookinfo 
b left join tb bookcase c on b.bookcase-c.id join tb publishing p on 
b.ISBN-p.ISBN join tb booktype t on b.typeid-t.id where b.del-0) as book 
on borr.bookid-book.id order by borr.degree desc limit 10"); 
$info-mysql fetch array ($sql) ;// 检 索 图 书 借阅 信息 
$i-1; 
dot 
?» «tr» 
«td height-"25" align-"center"»«?php echo $i;?»«/td» 
«td style-"padding:5px; "»&nbsp; <?php echo $info [barcode]; ?»«/td» 
«td style-"padding:5px;"»«?php echo $info[bookname];?»«/td» 
«td style-"padding:5px;"»«?php echo $info[typename];?»«/td» 


«td center"»&nbsp;«?php echo $info[bookcasename];?»«/td» 
«td center"»&nbsp;«?php echo $info[pubname];?»«/td» 

«td center"»«?php echo $info[author];?»«/td» 

«td center"»«?php echo $info[price];?»«/td» 


«td align-"center"»«?php echo $info[degree];?»«/td» 
«/tr» 
«?php 
人 $=$i+1;// 变 量 自 加 1 操作 
}while ($info=mysql fetch array($sql)); 
?» 
«/table»«/td»«/tr»«/table» 
«p»&nbsp; «/p»«/td»«/tr»«/table»«/td» 
«/tr» 
«/table» 
<?php include ("copyright.php"); ?»«/td» 
«/tr»«/table» 
</html> 
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今天 完成 了 系统 首页 的 设计 工作 。 我 仔细 浏览 了 具体 代码 和 界面 后 ， 觉 得 很 有 必要 对 
管理 员 进 行 管理 ， 并 需要 准确 无 误 地 判断 用 户 的 权限 。 如 果 在 开发 时 没有 和 弄 清 楚 ， 将 会 导 
致 用 户 信息 泄露 的 问题 发 生 。 


5.5 ”管理 员 登 录 
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刚刚 完成 系统 首页 的 设计 工作 ， 同 事 C 就 马上 开始 了 管理 员 登 录 模 块 的 设计 工作 。 系 
统 登 录 是 进入 学 校 图 书馆 系统 的 入 口 ， 主 要 用 于 验证 管理 员 的 身份 。 
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5.5.1 系统 登录 首页 


运行 本 系统 后 ， 首 先进 入 的 是 系统 登录 页 面 ， 在 该 页 面 中 ， 系 统管 理 员 可 以 通过 输入 
正确 的 管理 员 和 密码 登录 到 系统 首页 ， 如 图 5-5 所 示 。 


图 5-5 系统 登录 首页 


下 面 通过 一 段 代码 (login.php) 进 行 讲解 ， 具 体 如 下 : 
<html> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
<head> 
<title> 西 南 传媒 大 学 图 书馆 系统 </tit1le> 
«link href-"CSS/style.css" rel="stylesheet"> 
<script language-"javascript"» 
function check (form) {// 自 定义 一 个 Javasript 函数 
if (form.name.value==""){// 如 果 管 理 员 信息 为 空 ,弹出 提示 信息 
alert ("请 输入 管理 员 名 称 !") ; form. name. focus () ;return false; 
} 
if (form.pwd.value==""){// 如 果 管理 密码 为 空 ,弹出 提示 信息 
alert ("请 输入 密码 !") ; form.pwd.focus () ;return false; 


} 
) 
</script> 
</head> 
<body> 
«form name-"forml" method="post" action-"chklogin.php"» 
«table width-"100$" border-"0" cellspacing-"0" cellpadding-"0"» 
SETS 
«td width-"30$" bgcolor="86C1E6">&nbsp; </td> 
<td width="32%" background="Images/bg.gif"> 
<table width="603" height="243" border="0" align="center" cellpadding 
cellspacing="0" bordercolorlight="#FFFFFF" bordercolordark="#D2E3E6"> 
«tr» 
«td width-"50$" height-"100" align-"center"»&nbsp;«/td» 
«td width-"50$"»&nbsp; 
«/td» 
oA 
«tr» 
«td height-"90" rowspan-"3" align-"center"»&nbsp;«/td» 
«td height-"30" valign="top"> 管 理 员 名 称 : 
«input name="name" type="text" class-"logininput" id-"name3" size-"25"»«/td» 
«/tr» 
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<tr> 
«td height-"30" valign="top"> 管 理 员 密 码 : 

«input name-"pwd" type-"password" class-"logininput" id-"pwd2" size="25"></td> 

«/tr» 

«tr» 
«td height-"30" align="center" valign="top"> 
«input name-"submit" type="submit" class-"btn grey" value=" 俏 定 " 
onClick-"return check(forml)"» 
&nbsp; 
<input name-"submit3" type-"reset" class-"btn grey" value=" 重 置 "> 
&nbsp; 
«input name-"submit2" type-"button" class-"btn grey" value=" 关 闭 " 
onClick-"window.close();"»«/td» 

</tr> 

<tr> 

<td height="53" colspan="2" align="center"></td> 
</tr> 
</table></td> 
<td width-"30$" bgcolor="86C1E6"><br></td> 
«/tr» 
</table> 
<div align="center"><br> 

&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; 
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; 
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; 开发 笔记 技术 支持 </div> 
«/form» 
</body> 
</html> 


当 用 户 将 数据 提交 给 处 理 页 后 ， 页 面 中 为 了 防止 非法 用 户 进入 学 校 图 书 管理 系统 首页 ， 
通过 调用 类 来 实现 判断 用 户 名 和 密码 是 否 正确 ， 如 果 用 户 信息 正确 ， 可 以 登录 学 校 图 书 管 
理 系统 的 首页 ， 和 否则 弹出 提示 信息 ， 代 码 (chklogin.php) 如 下 : 

«?php 

session start(); 

$A name-$ POST[name]; // 接 收 表单 提交 的 用 户 名 

$A pwd=$ POST[pwd]; // 接 收 表单 提交 的 密码 

class chkinput{ // 定 义 类 


Var $name; 
var $pwd; 


function chkinput ($x, $y) { // 定 义 一 个 方法 
$this->name=$x;// 将 管理 员 名 称 传送 给 类 对 象 
$this->pwq=$y;// 将 管理 员 密 码 传送 给 类 对 象 
} 


function checkinput (){ 
include ("conn/conn.php"); // 连 接 数据 源 
$sql=mysql query ("select * from tb manager where name-'".$this-»name."' 
and pwd-'".$this-»pwd."'",$conn); 
$info-mysql fetch array ($sql); // 检 索 管 理 员 名 称 和 密码 是 否 正确 
if ($info==false) { // 如 果 管理 员 名 称 或 密码 不 正确 ， 则 弹出 相关 提示 信息 
echo "<script language='javascript'>alert (' 您 输入 的 管理 员 名 称 错误 ， 请 
重新 输入 ! ') ;history.back();</script>"; 
exit; 
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else{ // 如 果 管 理 员 名 称 或 密码 正确 ， 则 弹出 相关 提示 信息 
echo "«script»alert (' 管 理 员 登 录 成 功 !'); 
window.location-'index.php';«/script»"; 
$ SESSION[admin name]-$info [name]; 
$ SESSION[pwd]-$info[pwd]; 


$obj-new chkinput (trim($name) , trim ($pwd) ) ; // 创 建 对 象 


$obj->checkinput (); // 调 用 类 
?> 


552 ”查看 管理 员 


管理 员 登 录 后 ， 单 击 管理 员 设 置 链接 后 可 查看 管理 员 列 表 页 面 。 在 该 页 面 中 ， 将 以 表 
格 的 形式 显示 全 部 管理 员 及 其 权限 的 信息 ， 并 提供 添加 管理 员 信 息 、 删 除 管理 员 信息 和 设 
置 管理 员 权限 的 超 链接 ， 如 图 5-6 所 示 。 
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图 5-6 查看 管理 员 
下 面 通过 一 段 代码 (manager.php) 进 行 讲解 ， 具 体 如 下 : 


<?php session start();?» 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
<link href-"CSS/style.css" rel="stylesheet"> 
</head> 
<body> 
<table width="776" border="0" align="center" cellpadding="0" 
cellspacing="0" class="tableBorder"> 
«tr» 
«td» 
<?php include ("navigation.php");?» 
«/td» 
«/tr» 
«td» 
«table width-"100$" Pborder-"0" cellspacing-"0" cellpadding-"0"» 
«tr» 
«td valign="top" bgcolor-"£FFFFFF"»«table width-"99$" height-"510" 
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border="0" align-"center" cellpadding-"0" cellspacing-"0" 

bgcolor-"$FFFFFF" 
class-"tableBorder gray"» 

«tr» 
<td height-"510" valign="top" style-"padding:5px;"» 

«table width-"98$" height-"487" border-"0" cellpadding-"0" cellspacing-"0"» 

«tr» 
«td height-"22" valign="top" class-"word orange"> 当 前 位 置 : 系统 设置 «gt; 
管理 员 设 置 &gt;&gt; &gt; «/td» 

«/tr» 

<tr> 

<td align="center" valign="top"> 
<?php 
include ("conn/conn.php");// 连 接 数 据 库 文件 
$sql-mysql query ("select 
m.id,m.name,p.sysset,p.readerset,p.bookset,p.borrowback,p.sysquery from 
tb manager as m left join (select * from tb purview)as p on m.id=p.id"); 
$info=mysql_fetch_array ($sql) ;// 检 索 数据 信息 
if(Sinfo--false)( 
?> 
«table width="100%" height-"30" border="0" cellpadding-"0" 

cellspacing-"0"» 


«tr» 
«td height-"36" align="center"> 暂 无 管理 员 信息 ! </td> 
«/tr» 
</table> 
<table width-"100$" border="0" cellspacing="0" cellpadding="0"> 
«tr» 
«td» 


«a href="#" 
onClick-"window.open('manager add.php','','width-292,height-175')"» 
添加 管理 员 信息 </a> «/td» 
</tr> 
</table> 
<?php 
}else{ 
?» 
«table width-"100$" border="0" cellspacing-"0" cellpadding-" 
«tr» 
«td width-"84$"»&nbsp; «/td» 
«td width-"16$"» 
«a href="#" 
onClick-"window.open('manager add.php','','width-292,height-175')"» 
添加 管理 员 信息 </a> «/td» 
«/tr» 
«/table» 
«table width-"91$" border="1l" cellpadding-"0" cellspacing-"0" 
bordercolor-"£FFFFFF" bordercolordark-"£D2E3E6" 
bordercolorlight-"£FFFFFF"» 
«tr align="center" bgcolor-"£e3F4F7"» 
«td wiqdth="26%"> 管 理 员 名 称 </td> 
«td wiqdth="12%"> 系 统 设置 </td> 
«td width="12g%"> 读 者 管理 </td> 
«td width="128"> 图 书 档案 管理 </td> 
«td wiqdth="11%"> 图 书 借 还 </tq> 
«td wiqdth="11%"> 系 统 查 询 </td> 
«td width="8%"> 权 限 设置 </td> 
«td width="8%"> 操 作 </td> 
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«/tr» 
<?php do(?» 
«tr» 
«td style-"padding:5px;"»«?php echo $info[name];?»«/td» 
«td align="center"> 
«input name-"checkbox" type-"checkbox" class-"noborder" 
value-"checkbox" disabled-"disabled" 
<?php if($info[sysset]--1) (echo ("checked");}?>> 
«/td» 
«td align-"center"»«input name-"checkbox" type="checkbox" 
class-"noborder" value-"checkbox" disabled-"disabled" 
<?php if ($info[readerset]--1) (echo ("checked") ; }?>></td> 
«td align-"center"»«input name-"checkbox" type="checkbox" 
class-"noborder" value-"checkbox" disabled 
<?php if ($info[bookset]--1) (echo ("checked") ; | ?»»«/td» 
«td align-"center"»«input name-"checkbox" type="checkbox" 
class-"noborder" value-"checkbox" disabled 
<?php if (S$info[borrowback]--1) (echo ("checked") ; )?»»«/td» 
«td align-"center"»«input name-"checkbox" type="checkbox" 
class-"noborder" value-"checkbox" disabled 
<?php if (Sinfo[sysquery]--1) (echo ("checked") ; ) ?»»«/td» 
«td align="center"> 
«a href="#" onClick-"window.open('manager modify.php?id- 
<?php echo $info[id]; ?»','','width-292,height-175') "> 权限 设置 </a></td> 
«td align="center"> 
«a href-"manager del.php?id-«?php echo $info[id];?>"> 删 除 </a></td> 
«/tr» 
«?php 
)while(S$info-mysql fetch array($sq1l)); 
?> 
«/table»«/td» 
«/tr» 
«/table» 
«/td» 
«/tr» 
«/table»«?php include ("copyright.php");?»«/td» 
«/tr» 
«/table» 
«/td» 
«/tr» 
«/table» 
</body> 


5.5.8 ”添加 管理 员 


当 超 级 管理 人 员 登 录 后 ， 可 能 需要 添加 新 的 管理 人 员 来 协助 其 管理 系统 。 打 开 添 加 管 
理 员 信 息 页 面 后 的 运行 结果 如 图 5-7 所 示 。 
下 面 通过 一 段 代码 (mangaer_ok.php) 进 行 讲解 ， 具 体 如 下 : 


«?php 

include ("conn/conn.php"); 

if($ POST[submit] !-"") ( 

$name-$ POST [name]; 

$pwd-$ POST[pwd]; 

$sql-mysql query("insert into tb manager (name, pwd) values ('$name', '$pwd')"); 
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if ($sql==true) { 

echo "<script language=javascript>alert('" 管 理 员 添 加 成 功 ! '); 
window.close();window.opener.location.reload();«/script»"; 
H 

else{ 

echo "<script language=javascript>alert (' 管理 员 添 加 失败 ! '); 
window.close();window.opener.location.reload();«/script»"; 
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图 5-7 添加 管理 员 


5.5.4 ”设置 管理 员 权 限 的 过 程 


因为 不 同 的 管理 人 员 拥 有 不 同 的 权限 ， 所 以 必须 设置 管理 人 员 的 权限 。 当 超级 管理 人 
员 进入 系统 后 ， 可 以 设置 超级 管理 权限 ， 如 图 5-8 所 示 。 
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图 5-8 设置 管理 员 权 限 


下 面 通过 一 段 代码 (manager_modifyok.php) 进 行 讲解 ， 具 体 如 下 : 
<?php 
include ("conn/conn.php");// 连 接 数据 库 文件 
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if($ POST[submit] !=""){// 提 交 表 单 , 执行 以 下 操作 
$id=$_POST[iq];// 获 取 ID 信息 
$sysset-$ POST [sysset]—""?0:1; 
$readerset-$ POST[readerset]--""?0:1; 
$bookset-$ POST[bookset]--""2?0:1; 
$borrowback-$ POST [borrowback]--""?0:1; 
$sysquery-$ POST[sysquery]--""?0:1; 
$query-mysql query("select * from tb purview where id-$id"); 
$info-mysql fetch array ($query); /检索 权限 信息 表 中 是 否 存在 管理 员 
if ($info==false) {// 如 果 不 存在 , 向 权限 表 中 添加 管理 员 权 限 信息 

mysql query("insert into 
tb purview(id,sysset,readerset,bookset,borrowback, sysquery) 
values ($id,$sysset,S$readerset,$bookset,S$borrowback, $sysquery)");] 
else( // 和 否则 , 更 新 管理 员 的 权限 信息 

mysql query("update tb purview set 
sysset-$sysset,readerset-$readerset,bookset-$bookset,borrowback- 
$borrowback,sysquery-$sysquery where id-'$id'");) 

echo"«script language=javascript>alert('" 权 限 设置 修改 成 功 ! 1); 
window.close();window.opener.location.reload();«/script»"; 
// 更 新 成 功 , 弹出 提示 信息 , 并 更 新 父 窗口 } 


?> 


5.5.5 ”删除 管理 员 


在 现实 的 图 书馆 管理 工作 中 ， 有 可 能 会 涉及 人 员 调 动 ， 如 离职 、 退 休 或 者 岗位 变化 。 
当 这 些 情况 发 生 时 ， 需 要 在 系统 内 删除 其 对 应 的 管理 权限 。 在 本 系统 中 也 考虑 到 了 上 述 问 
题 ， 删 除 某 管理 员 的 界面 如 图 5-9 所 示 。 
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5-9 删除 管理 员 


下 面 通过 一 段 代码 (manager_del.php) 进 行 讲解 ， 具 体 如 下 : 

«?php 

include ("conn/conn.php");// 连 接 数据 库 

$id-$ GET[id];//3KWUE EAR) ID 号 

$sql=mysql_query ("delete from tb manager where id='S$id'") ;// 删 除 管理 员 信息 
$query-mysql query ("delete from tb purview where id="'$id'");// 删 除 管 理 员 权限 
if($sql==true and $query==true ){ 

echo "<script language-javascript»alert (' 管 理 员 删除 成 功 ! '); 
history.back();</script>"; 
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l; 

else{ 

echo "<script language=javascript>alert(' 管 理 员 删除 失败 ! '); 
history.back();</script>"; 

l 


?» 


R, 07 04 
今天 同事 C 完成 了 管理 员 登 录 模 块 的 编码 工作 。 我 浏览 代码 后 感慨 颇 多 ， 我 发 现在 管 
理 员 所 有 的 管理 功能 中 ， 例 如 查看 管理 员 、 添 加 管理 员 、 设 置 管理 员 权限 等 ， 它 们 的 实现 
目标 都 是 一 致 的 ， 主 要 功能 都 是 更 好 地 管理 图 书 系统 。 


56 图 书 档案 管理 设计 


图 书 档案 管理 功能 是 该 系统 最 重要 的 功能 模块 之 一 ， 主 要 涉及 查看 图 书 列表 、 添 加 图 
书信 息 、 修 改 图 书信 息 、 删 除 图 书信 息 和 查看 图 书 详细 信息 几 个 小 模块 。 此 模块 功能 也 是 
由 同事 C 来 完成 的 。 

5.6.1 查看 图 书 列表 


当 管 理 员 登 录 系 统 后 ， 进 入 到 查看 图 书 列表 页 面 ， 在 该 页 面 中 将 显示 全 部 的 图 书信 息 
列表 ， 如 图 5-10 所 示 。 
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5-10 ”查看 图 书 列表 
实现 它 也 十 分 简单 ， 下 面 通过 一 段 代 码 (book.php) 进 行 讲解 ， 具 体 如 下 : 
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<?php session start();?» 
«html» 
<head> 
<title> 图 书馆 管理 系统 </title> 
«link href-"CSS/style.css" rel="stylesheet"> 
</head> 
<body> 
<table width="778" border="0" align="center" cellpadding="0" 
cellspacing="0" class="tableBorder"> 
«tr» 
«td» 
<?php include ("navigation.php");?» 
«/td» 
</tr> 
<td> 
<table width="100%" border="0" cellspacing="0" cellpadding="0"> 
<tr> 
<td valign="top" bgcolor="#FFFFFF"><table width-"99$" height-"510" 
border="0" align="center" cellpadding="0" cellspacing="0" 
bgcolor="#FFFFFF" class="tableBorder gray"> 
<tr> 
<td height-"510" valign="top" style="padding: 5px;"><table width="98%" 
border="0" cellpadding="0" cellspacing="0"> 
<tr> 
«td height-"22" valign="top" class="word_orange"> 当 前 位 置 ; 图 书 管理 
&gt; 图 书 档案 管理 &gt;&gt;&gt;«/td» 
</tr> 
<tr> 
<td align="center" valign="top"> 
<?php 
include ("Conn/conn.php"); 
$query-mysql query("select book.barcode,book.id as 
bookid,book.bookname,bt.typename,pb.pubname,bc.name from tb bookinfo book 
join tb booktype bt on book.typeid-bt.id join tb publishing pb on 
book.ISBN-pb.ISBN join tb bookcase bc on book.bookcase-bc.id"); 
$result-mysql fetch array ($query); 
if($result--false)( 


?» 
«table width-"100$" height-"30" border-"0" cellpadding-"0" cellspacing-"0"» 
«tr» 
«td height-"36" align="center"> 暂 无 图 书信 息 ! </td> 
«/tr» 
«/table» 
«table width-"100$" Pborder-"0" cellspacing-"0" cellpadding-"0"» 
«tr» 
«td» 
«a href-"book add.php"> 添 加 图 书信 息 </a> «/td» 
«Er» 
</table> 
<?php 
}else{ 
R> 
«table width-"100$" border="0" cellspacing="0" cellpadding="0"> 
<tr> 
«td width="87%">&nbsp; </td> 


<td width="13%"> 
<a href="book add.php"> 添 加 图 书信 息 </a></td> 
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SET» 
«/table» 
«table width-"98$" Pborder-"1" cellpadding-"0" cellspacing-"0" 
bordercolor-"£FFFFFF" bordercolordark-"£D2E3E6" 
bordercolorlight-"£$FFFFFF"» 
«tr align="center" bgcolor-"£e3F4F7"» 
«td width="13%"> 条 形 码 </td> 
«td width="26%"> 图 书 名 称 </td> 
«td width="15s"> 图 书 类 型 </td> 
«td width="14%"> 出 版 社 </td> 
«td width="12%"> 书 架 </td> 
«td width="6%"> 修 改 </td> 
«td wiqdth="5%"> 删 除 </td> 
«/tr» 
«?php do( ?» 
«tr» 
«td style-"padding:5px;"»&nbsp;«?php echo $result [barcode]; ?»«/td» 
«td style-"padding:5px;"»«a href-"book look.php?id- 
<?php echo $result [bookid]; ?»"»«?php echo $result [bookname] ; ?»«/a»«/td» 
«td style-"padding:5px;"»&nbsp; 
<?php echo $result[typename];?»«/td» 
«td style-"padding:5px;"»&nbsp; 
<?php echo $result [pubname];?»«/td» 
«td style-"padding:5px;"»&nbsp; 
<?php echo $result [name] ;?></td> 
<td align="center"><a href="book Modify.php?id= 
<?php echo $result [bookid] ;?>"> 修 改 </a></td> 
«td align="center"><a href-"book del.php?id- 
<?php echo $result [bookid] ;?>"> 删 除 </a></td> 
«/tr» 
«? 
)while($result-mysql fetch array ($query)); 
> 
</table></td> 
</tr> 
</table> 
</td> 
cy eres 
«/table»«?php include ("copyright.php");?»«/td» 
tr» 
</table> 
</td> 
«/tr» 
</table> 
</body> 
</html> 


56.2 ”添加 图 书信 息 
当 图 书馆 新 引进 了 图 书后 ， 需 要 在 图 书馆 管理 系统 录入 这 些 新 书 的 信息 ， 以 便 及 时 供 


老师 和 同学 借阅 ， 录 入 系统 的 方法 十 分 简单 ， 只 需 单 击 “ 添 加 图 书信 息 ” 超 链接 即 可 录入 ， 
如 图 5-11 所 示 。 
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图 5-11 添加 图 书信 息 
下 面 通过 一 段 代 码 (book_add.php) 进 行 讲解 ， 具 体 如 下 : 


«?php session start();?» 
«html» 
«head» 
<title> 图 书馆 管理 系统 </title> 
<link href="CSS/style.css" rel="stylesheet"> 
</head> 
<script language="javascript"> 
function check (form){ 
if(form.barcode .value==""){ 
alert ("请 输入 条 形 码 1!") ; form.barcode.focus();return false; 
if (form.bookName .value=="") { 
alert ("请 输入 图 书 姓名 !") ; form.bookName .focus () ;return false; 
) 
if(form.price.value--"")( 
alert ("请 输入 图 书 定价 !") ; form.price.focus();return false; 


} 
form.submit(); 
5 
</script> 


<body> 
<table width="776" border="0" align="center" cellpadding="0" 


cellspacing="0" class="tableBorder"> 
«tr» 
«td» 
<?php include ("navigation.php");?» 
«/td» 
«/tr» 
«td» 
«table width-"100$" border="0" cellspacing-"0" cellpadding-"0"» 


«tr» 
«td valign="top" bgcolor-"£FFFFFF"»«table width-"99$" height-"510" 


border-"0" align="center" cellpadding-"0" cellspacing-"0" bgcolor="#FFFFFF" 
class-"tableBorder gray"» 
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<tr> 
«td height-"510" align-"center" valign-"top" 
style-"padding:5px;"»«table width-"98$" height-"487" border-"0" 
cellpadding-"0" cellspacing-"0"» 
EI 
«td height-"22" valign="top" class-"word orange"» 
当前 位 置 : 图 书 档案 管理 sgt; 添加 图 书信 息 &gt;&gt;&gt;«/td» 
«/tr» 
«tr» 
«td align-"center" valign-"top"»«table width- 
"100%" height-"493" border-"0" cellpadding-"0" cellspacing-"0"» 
«tr» 
«td align="center" valign="top"> 
<form name="forml" method="post" action-"book ok.php"> 
<table width="600" height="432" border="0" cellpadding= 
"0" cellspacing="0" bgcolor="#FFFFFF"> 
«tr» 
«td width-"173" align="center"> 条 gnbsp; 形 enbsp; 码 : </td> 
<td width="427" height="39"> 
<input name-"barcode" type="text" id="barcode"></td> 
</tr> 
<tr> 
«td align="center"> 图 书 名 称 : </td> 
<td height="39"><input name="bookName" type="text" id= 
"bookName" size="50"> * </td> 
</tr> 
<tr> 
«td align="center"> 图 书 类 型 : </td> 
«td» 
<select name-"typeId" class-"wenbenkuang" id-"typeId"» 
«?php 
include ("Conn/conn.php"); 
$sql-mysql query ("select * from tb booktype"); 
$info-mysql fetch array($sql); 
dot 
2> 
<option value="<?php echo $info[id];?>"> 
<?php echo $info[typename];?></option> 
<?php }while ($info=mysql fetch array ($sql) );?> 
</select> 
</td> 
«/tr» 
«tr» 
«td align-"center"»[F&nbsp; &nbsp; 4i: </td> 
<td><input name-"author" type="text" id-"author" size-"40"»«/td» 
«/tr» 
«tr» 
«td align-"center"»if&nbsp;&nbsp; 者: </td> 
«td»«input name-"translator" type-"text" id-"translator" 
size-"40"»«/td» 
«/tr» 
«tr» 
«td align="center"> 出 gnbsp; 版 enbsp; 社 : </td> 
«td» 
«select name-"isbn" class-"wenbenkuang"» 
«?php 
$sql2-mysql query("select * from tb publishing"); 
$info2-mysql fetch array($sql2); 
dot 
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2: 
<option value-"«?php echo $info2[ISBN];?»"» 
<?php echo $info2[pubname];?»«/option» 
<?php )while($info2-mysql fetch array($sq12));?» 
«/select» 
«/td» 
«/tr» 
«tr» 
«td align-"center"»Íff&nbsp; gnbsp; 格 : </td> 
<td><input name-"price" type="text" id="price"> (元 )</td> 
«/tr» 
«tr» 
«td align="center"> H &nbsp; &nbsp;lij: </td> 
<td><input name="page" type="text" id="page"></td> 
</tr> 
<tr> 
<td align="center"> Ħ&nbsp; gnbsp; 架 : </td> 
<td><select name-"bookcaseid" class-"wenbenkuang" id-"bookcaseid"» 
«?php 
$sql3-mysql query("select * from tb bookcase"); 
$info3-mysql fetch array($sq13); 
do( 
?» 
<option value-"«?php echo $info3[id];?»"» 
<?php echo $info3[name];?»«/option» 
<?php )while($info3-mysql fetch array($sg13));?» 
«/select» 
«input name-"operator" type- 
<?php echo $info3[name];?»"»«/td» 
«/tr» 
«tr» 
«td align-"center"»&nbsp;«/td» 
«td»«input name-"Submit" type-"submit" class-"btn grey" value=" 保 存 " 
onClick-"return check (forml)"»&nbsp; 
«input name-"Submit2" type-"button" class-"btn grey" value-" 
返回 " onclick-"history.back();"»«/td» 
«/tr» 
</table> </form> 
«/td» «/tr» 
«/table»«/td» 
ctr» 
«/table»«/td» 
tr» 
«/table»«?php include ("copyright.php");?»«/td» 
«/tr» 
«/table» 
«/td» 
«/tr» 
«/table» 
</body> 
</html> 


当 管 理 者 填写 表单 时 ， 需 要 将 数据 提交 给 另外 一 个 页 面 进行 处 理 ， 将 这 些 数据 添加 到 
数据 库 中 。 其 实现 代码 (book_ok.php) 如 下 : 


<?php 

session start(); 

include ("Conn/conn.php"); 
S$operator-$ SESSION[admin name]; 
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hidden" id-"operator" value-" 


War 一 


T 


$barcode-$ POST[barcode]; 

$bookName-$ POST[bookName]; 

$typeid=$ POST[typeId]; 

$author-$ POST[author]; 

$translator-$ POST[translator]; 

$isbn-$ POST[isbn]; 

$price-$ POST[price]; 

$page-$ POST [page]; 

$bookcase=$ POST [bookcaseid]; 

$inTime=date ("Y-m-d"); 

$sql=mysql query ("insert into 

tb bookinfo (barcode, bookName, typeid, author, translator, ISBN, price, page, 
bookcase, inTime, operator ) values ('$barcode', '$bookName', '$typeid', '$author', 
'Stranslator','$isbn','$price','$page', '$bookcaseid', '$inTime', '$operator')"); 
echo "<script language='javascript'>alert(' 图 书信 息 添 加 

成 功 !') ;history.back();«/script»"; 

o 

«meta http-equiv-"Content-Type" content-"text/html; charset-gb2312"» 


5.6.3 ”修改 图 书信 息 


添加 的 新 图 书信 息 不 一 定 完 全 正确 ， 出 错 的 原因 也 会 多 种 多 样 ， 所 以 必须 设置 图 书馆 
图 书信 息 的 修改 功能 ， 如 图 5-12 所 示 。 


OS nn pna is 
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5-12 ”修改 图 书信 息 
下 面 通 过 一 段 代 码 (book_Modify_ok.php) 进 行 讲解 ， 具 体 如 下 : 
«?php 
session start(); // 初 始 化 变量 
include ("Conn/conn .php") ;// 连 接 数据 库 
$bid-$ POST[bid]// 获 取 ID 图 书号 


$operator=$ SESSION[admin name];// 获 取 图 书 管理 员 名 称 
$barcode=$_POST[barcode];// 获 取 图 书 条 形 码 
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$bookName-$ POST[bookName] ;// 获 取 图 书 名 称 

$typeid-$ POST[typeId];// 获 取 图 书 类 型 id 号 

$author=$_POST [author] ;// 获 取 图 书 作者 

$translator=$ POST[translator];// 获 取 图 书 译 者 

$isbn=$_POST [isbn] ;获取 出 版 社 ISBN 号 

$price=$_POST [price];// 获 取 图 书 单价 

$page-$ POST [page];// 获 取 图 书页 码 

$bookcase=$ POST[bookcaseid] ;// 获 取 图 书 书架 ID 号 

$inTime-date ("Y-m-d") ;// 设 置 图 书 更 新 时 间 为 当前 时 间 

$query-mysql query("update tb bookinfo set barcode-'$barcode', 
bookName-'$bookName' , typeid-'$typeid', author-'$author', 
translator-'$translator', ISBN-'$isbn' , price-'$price' , page-'$page' , 
bookcase-'$bookcaseid', inTime-'$inTime', operator-'$operator' where 
id-$bid"); 

echo "<script language='javascript'>alert (' 图 书信 息 修 改 成 

功 !') ;history.back();</script>"; 

?» 

«meta http-equiv-"Content-Type" content-"text/html; charset-gb2312"» 


5.6.4 删除 图 书信 息 


当 一 些 图 书信 息 过 期 或 者 已 经 下 架 时 ， 需 要 将 这 些 图 书 的 信息 删除 ， 下 面 通过 一 段 代 
人 码 (book.del) 进 行 讲解 ， 具 体 如 下 : 

<?php 

include ("Conn/conn.php"); 

$info del-mysql query("delete from tb bookinfo where id-$ GET[id]"); 

if ($info del)( 
echo "<script language-'javascript'»alert (' 图 书信 息 删除 成 功 !'); 
history.back();</script> "7 


5.7. 图书 借 还 功能 的 实现 


核心 功能 的 实现 


今天 开始 实现 整个 系统 最 为 核心 的 功能 ， 此 功能 由 同事 D 负责 实现 。 该 模块 的 开发 难 
度 也 比较 大 ， 在 这 个 模块 中 ， 主 要 包括 图 书 借阅 、 图 书 续 借 、 图 书 归 还 、 图 书 档案 查询 、 
图 书 借阅 查询 、 借 阅 到 期 提醒 等 功能 。 


5.7.1 图 书 借阅 实现 功能 


当 读 者 进入 系统 后 ， 系 统 会 自动 搜 出 该 读者 的 基本 信息 和 未 归还 的 图 书信 息 ， 搜 索 出 
的 信息 将 显示 在 该 页 面 ， 此 时 输入 条 形 码 或 图 书 名 称 并 单 击 “ 确 定 ” 按 钮 后 完成 整个 操作 。 
图 书 借 还 模块 如 图 5-13 所 示 。 


bad 
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图 5-13 ”图书 借 还 模块 


下 面 通过 一 段 代码 (bookBorrow.php) 进 行 图书 借 还 功能 的 讲解 ， 具 体 如 下 : 


<script language="javascript"> 
function checkreader (form) {// 自 定义 一 个 函数 
if(form.barcode.value--"") {// 如 果 读 者 条 形 码 为 空 
alert ("请 输入 读者 条 形 码 !") ;form.barcode.focus () ;return;// 弹 
出 提示 
} 
form.submit(); 
) 
function checkbook (form) { 
if(form.barcode.value==""){// 如 果 查 询 文本 为 空 弹出 提示 
alert ("请 输入 读者 条 形 码 !") ; form.barcode.focus () ; return; 
} 
if(form.inputkey.value--"")( 
alert ("请 输入 查询 关键 字 !") ; form. inputkey.focus () ; return; 
) 
if(form.number.value-form.borrowNumber.value«-0)( 
alert (" 您 不 能 再 借阅 其 他 图 书 了 !") ; return; 
) 
form.submit(); // 提 交 表 单 
} 
</script> 
</head> 
<body> 
<?php include ("navigation.php");?> 
«table width-"776" border="0" cellspacing-"0" cellpadding-"0" 
align="center"> 
«tr» 
«td valign="top" bgcolor-"£FFFFFF"» 
«table width-"100$" height-"509" border="0" align-"center" cellpadding-"0" 
cellspacing-"0" bgcolor-"£FFFFFF" class-"tableBorder gray"» 
tgo 
«td align="left" valign="top" style-"padding:5px;"» &nbsp; 
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«span class-"word orange"»&nbsp; 当前 位 置 : 图 书 借 还 sgt; 图 书 借阅 &gt; agt; agt; 
«/span»«br» 

«table width-"96$" border-"0" align="center" cellpadding-"0" 
cellspacing-"0" bordercolor-"£FFFFFF" bgcolor-"£9ECFEE" 
class-"tableBorder grey"» 

«tr» 
<td height-"33" valign="top" background-"Images/bookborr.gif"» 
«table width-"100$" border-"0" cellpadding-"0" cellspacing-"0" 
bgcolor-"£FFFFFF"» 
«tr» 
«td valign-"top"»«table width-"100$" border-"0" cellpadding-"0" 
cellspacing-"0"» 
«tr» 
«td height-"33" 
background-"Images/bookborr.gif"»&nbsp;«/td» 
LIET 
</table> 
<table width="100%" height="21" border="0" cellpadding="0" 
cellspacing="0"> 
<tr> 
<td width-"24$" height-"18" style-"padding-left:7px;padding-top:7px;"» 
«img src-"Images/bg line.gif" width-"132" height-"20"»«/td» 

«td width-"76$" style="padding-top:7px;"> 读 者 条 形 码 : 
<input name="barcode" type="text" id="barcode" size="24" value="<?php echo 
$info[barcode];?>"> 

&nbsp; 
«input name-"Button" type-"button" class-"btn grey" value=" 确 定 " 
onClick-"checkreader (forml) "></td> 
</tr> 
</table></td> 
</tr> 
<tr> 
«td height="13" align="left" style="padding-left:7px;"><hr 
width="90%" size="1"></td> 
</tr> 
<tr> 
<td align="center"><table width="96%" border="0" 
cellpadding="0" cellspacing="0"> 
«tr» 
«td height-"27"»l/t&nbsp; &nbsp; &nbsp; &nbsp; 44: 

«input name-"readername" type-"text" id-"readername" 
value-"«?php echo $info[name];?»"» 

«input name-"readerid" type-"hidden" id-"readerid" 
value-"«?php echo $info[id];?»"»«/td» 

«td»TE&nbsp; &nbsp; &nbsp; &nbsp; Jil: 

«input name-"sex" type-"text" id-"sex" value-" 
<?php echo $info[sex];?»"»«/td» 

<td> 读 者 类 型 : 

<input name="readerType" type="text" id="readerType" 
value-"«?php echo $info[typename];?»"»«/td» 

«/tr» 
«tr» 
«td height="27"> 证 件 类 型 : 

<input name-"paperType" type="text" id-"paperType" 
value-"«?php echo $info[paperType];?»"»«/td» 

<td> 证 件 号 码 : 

«input name-"paperNo" type-"text" id-"paperNo" 
value-"«?php echo $info[paperNO];?»"»«/td» 
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<td> 可 借 数 量 : 
<input name-"number" type-"text" id-"number" value- 
"<?php echo $info[number];?»" size-"17"» 
D 
&nbsp; «/td» 
«/tr» 
</table></td> 
«/tr» 
</table></td> 
</tr> 
<tr> 
«td height="32">&nbsp; 添 加 的 依据 : 
«input name-"f" type-"radio" class-"noborder" value-"barcode" 
checked» 
图 书 条 形 码 &nbsp; &nbsp; 
<input name="f" type="radio" class="noborder" value="bookname"> 
KB nbsp; &nbsp; 
<input name-"inputkey" type="text" id-"inputkey" size-"50"» 
«input name-"Submit" type="button" class="btn grey" id-"Submit" 
onClick-"checkbook(forml);" value=" 确 定 "> 
«input name-"operator" type="hidden" id-"operator" value-"«?php 
echo $ SESSION[adminname];?»"» 
«input name-"Button2" type-"button" class-"btn grey" id-"Button2" 
onClick-"window.location.href-'bookBorrow.php'" value=" 完 成 借阅 "></td> 
«/tr» 
«tr» 
«td valign="top" bgcolor-"£D2E5Fl" style-"padding:5px"» 
«table width-"99$" border-"1" cellpadding-"0" cellspacing-"0" 
bordercolor-"£FFFFFF" bordercolorlight-"£$FFFFFF" 
bordercolordark-"£9ECFEE" bgcolor-"£FFFFFF"» 
«tr align="center" bgcolor-"£E2FAF6"» 
«td width-"29$" height="25"> 图 书 名 称 </td> 
«td width="12%"> 借 阅 时 间 </td> 
«td width="14%"> 应 还 时 间 </td> 
«td width="17%"> 出 版 社 </td> 
«td width="14%"> 书 架 </td> 
«td colspan="2"> 定 价 (元 ) </td> 
</tr> 
«?php 
$readerid-$info[id]; 
$sqll=mysql query ("select r.*,borr.borrowTime,borr.backTime,book.bookname, 
book.price,pub.pubname,bc.name as bookcase from tb borrow as borr join 
tb bookinfo as book on book.id-borr.bookid join tb publishing as pub on 
book.ISBN-pub.ISBN join tb bookcase as bc on book.bookcase-bc.id join 
tb reader as r on borr.readerid-r.id where borr.readerid-'$readerid' and 
borr.ifback-0"); 
//$sql-mysql query("select t.days from tb bookinfo b left join tb booktypet 
on b.typeid-t.id where b.barcode-'$barcode'"); 
$infol-mysql fetch array ($sq11); 
$borrowNumber-mysql num rows ($sqll); // 获 取 结 果 集中 行 的 数目 
do 
xd 


«tr» 
«td height-"25" style-"padding:5px;"»&nbsp; 
<?php echo $infol[bookname];?»«/td» 
«td style-"padding:5px; "»&nbsp; 
<?php echo $infol[borrowTime];?»«/td» 
«td style-"padding:5px; "»&nbsp; 
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<?php echo $infol[backTime];?»«/td» 
i "center"»5&nbsp;«?php echo $infol[pubname];?»«/td» 
"center"»&nbsp;«?php echo $infol[bookcase];?»«/td» 
«td width-"14$" align-"center"»&nbsp; «?php echo $infol[price]; ?»«/td» 
</tr> 
<?php 
}while ($infol=mysql_fetch_array ($sq11)); 
?> 


<input name-"borrowNumber" type="hidden" id-"borrowNumber" 
value-"«?php echo $borrowNumber; ?>"> 
</table></td> 
«/tr» 
«/table»«/td» 

«/tr» 

</table> 
<?php include ("copyright.php");?»«/td» 

«/tr» 
</table> 
</body> 
</html> 


5.7.2 图书 续 借 功能 


当 借阅 的 图 书 到 期 时 ， 如 果 借 书 人 员 还 需要 继续 阅读 ， 他 只 需要 办 理 续 借 手 续 就 可 以 
了 。 续 借 功 能 界面 如 图 5-14 所 示 。 


https//127.0.0.1/veb/05tushu/bookReney, php — Windows Internet Explorer 
0o- e 127.0.0.1 PE 


He RRR | http://127.0.0. 1/web/0Stushu/bookRener. php h-B8 


当前 位 置 : DAT > Dese 


ierse 


读者 验证 
读者 条 形 码 : 


图 5-14 ”图 书 续 借 界面 
下 面 通过 一 段 代码 (bookRenew.php) 进 行 讲解 ， 具 体 如 下 : 


«?php session start(); ?> 
«html» 
<head> 
<link href-"CSS/style.css" rel="stylesheet"> 
</head> 
<body> 
<script language="javascript"> 
function checkreader (form) { 
if(form.barcode.value--"")( 
alert ("请 输入 读者 条 形 码 !") ; form. barcode. focus () ; return; 
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} 
form.submit (); 
} 
</script> 
<table width="776" border="0" align="center" cellpadding="0" 
cellspacing="0" class="tableBorder"> 
<tr> 
«td» 
<?php include ("navigation.php");?» 
«/td» 
</tr> 
<td> 
<table width="100%" border="0" cellspacing="0" cellpadding="0"> 
<tr> 
<td valign="top" bgcolor="#FFFFFF"> 
<table width="99%" height="510" border="0" align="center" cellpadding="0" 
cellspacing="0" bgcolor="#FFFFFF" class="tableBorder gray"> 
«tr» 


="510" align-"center" valign-"top" style-"padding:5px;"» 
8$" height-"487" border-"0" cellpadding-"0" 


«td align="left" valign="top"> 
<?php 
include ("conn/conn.php"); 
$sql=mysql query ("select borr.id as 
borrid,borr.borrowTime,borr.backTime,borr.ifback,r.*,t.name as 
typename,t.number,book.bookname,book.price,pub.pubname,bc.name as 
bookcase from tb borrow as borr join tb reader r on borr.readerid-r.id join 
tb readerType t on r.typeid-t.id join tb bookinfo as book on 
book.id-borr.bookid join tb publishing as pub on book.ISBN-pub.ISBN join 
tb bookcase as bc on book.bookcase-bc.id where r.barcode-'$barcode' and 
borr.ifback=0") ;// 搜 索 读者 信息 和 该 读者 的 借阅 信息 
$info-mysql fetch array ($sql); 
?» 
«form name-"forml" method="post" action-""» 
«table width-"96$" border="0" cellspacing-"0" cellpadding-"0"» 
«tr» 
«td height-"30"»«span class-"word orange"»&nbsp; 
当前 位 置 ， 图 书 借 还 &gt; 图 书 续 借 &gt; ggt; ggt; «/span»«/td» 
«/tr» 
«/table» 
«table width-"100$" border-"0" cellpadding-"0" cellspacing-"0" 
class-"tableBorder gray"» 
«tr» 
«td valign-"top"»«table width-"100$" border-"0" cellpadding-"02" 
cellspacing-"2" bordercolor-"£AABBBD"» 
«tr» 
«td width-"739" height-"34" background-"Images/bookxj.gif"»&nbsp;«/td» 
«/tr» 
«tr» 
«td valign="top" bgcolor-"£D2E5Fl"» 


«table width-"100$" border-"0" cellpadding-"0" cellspacing-"0" 
bgcolor-"£FFFFFF"» 
«tr» 
«td width-"33$"»«table width-"100$" height-"74" border-"0" 
cellpadding-"0" cellspacing-"0"» 
«tr» 
«td height-"27" colspan-"2" align="center"> 
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«table width-"90$" height-"21" border-"0" cellpadding-"0" cellspacing-"0"» 
«tr» 
«td width-"132" background-"Images/bg line.gif"»&nbsp;«/td» 
«td»&nbsp;«/td» 
«/tr» 
</table></td> 
</tr> 
«tr» 
<td width-"8$" height-"27"»&nbsp;«/td» 
«td width="92$"> 读 者 条 形 码 : </td> 
«/tr» 
«tr» 
«td height-"27" colspan-"2" align="center"> 
«input name-"barcode" type-"text" id-"barcode" value-" 
<?php echo $info[barcode];?»" size-"24"» 
&nbsp; 
«input name-"Button" type-"button" class-"btn grey" value- 
"确定 "onClick="checkreader (forml)"»«/td» 
</tr> 
</table></td> 
<td width="1%" align="center" valign="bottom"> 
<img src="Images/borrow fg.gif" width="18" height="111"></td> 
<td width="66%" align="right"> 
<table width="96%" border="0" cellpadding="0" cellspacing="0"> 
<tr> 
«td height="27"> 姓 gnbsp; &nbsp; &nbsp; &nbsp; 4: 
«input name-"readername" type-"text" id-"readername" 
value-"«?php echo $info[name];?»"»«/td» 
<td> 性 gnbsp; &nbsp; &nbsp; &nbsp; Jil: 
«input name-"sex" type-"text" id-"sex" value-" 
<?php echo $info[sex];?»"»«/td» 
«/tr» 
«tr» 
«td height="27"> 证 件 类 型 : 
«input name-"paperType" type-"text" id-"paperType" 
value-"«?php echo $info[paperType];?»"»«/td» 
<td> 证 件 号 码 : 
«input name-"paperNo" type-"text" id-"paperNo" value= 
"<?php echo $info[paperNO];?»"»«/td» 
«/tr» 
«tr» 
«td height="27"> 读 者 类 型 : 
<input name="readerType" type="text" id= 
"readerType" value-"«?php echo $info[typename];?»"»«/td» 
<td> 可 借 数 量 : 
«input name-"number" type-"text" id-"number" value- 
"<?php echo $info[number];?»" size-"17"» 
bi 
&nbsp;«/td» 
«/tr» 
</table> </td> 
«/tr» 
</table> </td> 
«/tr» 
«tr» 
«td valign="top" bgcolor-"£D2E5Fl"» 
«table width-"100$" height-"35" border-"1" cellpadding-"0" cellspacing-"0" 
bordercolor-"£FFFFFF" bordercolorlight-"£FFFFFF" 
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bordercolordark-"$D2E3E6" bgcolor-"£FFFFFE"» 
«tr align="center" bgcolor-"$£e3F4F7"» 

«td width-"24$" height-"25" bgcolor="#F1F9FFE"> 图 书 名 称 </td> 

«td width-"12$" bgcolor="#F1F9FF"> 借 阅 时 间 </td> 

«td width-"13$" bgcolor="#F1F9FF"> 应 还 时 间 </td> 

«td width-"14$" bgcolor="#F1F9FE"> 出 版 社 </td> 

«td width-"12$" bgcolor="#FE1F9FE"> 书 架 </td> 

«td bgcolor="#F1F9FF"> 定 价 (元 ) </td> 

«td width-"12$" bgcolor-"£FlF9FF"»«input name-"Button22" 
type-"button" class-"btn grey" value=" 完 成 续 借 " 
onClick-"window.location.href-'bookRenew.php'"»«/td» 


</tr> 
<?php 
if($info)t 
do( ?> 

«tr» 


«td height-"25" style="padding: 5px; ">&nbsp; 
<?php echo $info[bookname] ; ?></td> 
<td style="padding: 5px; ">&nbsp; 
<?php echo $info[borrowTime];?»«/td» 
«td style-"padding:5px;"»&nbsp; 
<?php echo $T-$info[backTime];?»«/td» 
«td align-"center"»&nbsp; 
<?php echo $info[pubname]; ?»«/td» 
«td align-"center"»&nbsp; 
<?php echo $info[bookcase]; ?»«/td» 
«td width-"13$" align-"center"»&nbsp; 
«?php echo $info[price];?»«/td» 
«td width-"12$" align-"center"»«a href-"borrow oncemore.php?barcode- 
<?php echo $info[barcode];?»&borrid- 
<?php echo $info[borrid];?»&backTime- 
<?php echo $info[backTime];?»"»4E[f«/a»&nbsp; </td> 
«/tr» 
<?php )while(S$info-mysql fetch array($5g1));)?» 
«/table» 
«/td» 
«/td» 
«/tr» 
«/table» 
<?php include ("copyright.php");?»«/td» 
«/tr» 
«/table» 
«/td» 
«/tr» 
«/table» 
</body> 
</html> 


5.7.3 图 书 借阅 查询 功能 
图 书 借阅 查询 功能 用 于 快速 搜索 显示 馆 内 图 书 的 借阅 信息 。 此 功能 是 一 个 基本 的 检索 


表单 功能 ,在 具体 实现 时 通过 自 定义 的 JavaScript 函数 来 验证 输入 的 查询 条 件 是 否 合 法 。 具 
体 效 果 如 图 5-15 所 示 。 
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我 最 起 要 的 化 要 有 2009-12-08 
历史 是 个 什么 玩意 儿 1-4 2010-01-05 
历史 是 个 什么 玩意 儿 I-4 * 2010-01-08 
1934 BOOK? 34136345654 2010-12-08 
历史 是 个 什么 玩意 儿 I-4 p 2010-12-05 
19:4 moore 34134349694 2010-12-08 


1094 Book? 1234563450343 2009-12-06 


1938 , 我 起 和 世界 该 该 12345678989911 2010-01-05 


FOES 


图 5-15 图 书 借阅 查询 
下 面 通过 一 段 代码 (bookQuery.php) 进 行 讲解 ， 具 体 如 下 : 


<?php session start();?> 
«html» 
«head» 
<title> 图 书馆 管理 系统 </title> 
<link href="CSS/style.css" rel="stylesheet"> 
</head> 
<body> 
«table width-"776" border="0" align-"center" cellpadding-"0" 
cellspacing-"0" 
class-"tableBorder"» 
«tr» 
«td» 
«?php include ("navigation.php"); ?> 
«/td» 
«/tr» 
«td» 
«table width-"100$" border="0" cellspacing-"0" cellpadding-"0"» 


"top" bgcolor-"£4FFFFFF"» 
99$" height-"510" border-"0" align="center" cellpadding-"0" 
"0" bgcolor-"£4FFFFFF" class-"tableBorder gray"> 


cellspacing- 
«tr» 
«td height-"510" align-"center" valign-"top" style-"padding:5px;"» 
«table width-"98$" height-"487" Pborder-"0" cellpadding-"0" 
cellspacing-"0"» 
«tr» 
«td align="center" valign="top"> 
<table width="723" height="37" border="0" cellpadding="0" 
cellspacing="0"> 
<tr> 
«td background-"Images/dangan.gif"»&nbsp;«/td» 
«/tr» 
</table> 
«form name-"forml" method="post" action=""> 
<table width="98%" height-"38" border="1" cellpadding="1" 
cellspacing="0" bordercolor="#FFFFFF" bgcolor="#9ECFEE" 
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class-"tableBorder gray"» 
«tr» 
«td align-"center"» 
&nbsp;«img src-"Images/search.gif" width-"37" height-"29"»«/td» 
<td>gnbsp; &nbsp; 请 选择 查询 依据 : 
<select name="f" class="wenbenkuang" id="f"> 
<option value="<?php echo "b.barcode";?>"> 条 形 码 </option> 
<option value="<?php echo "t.typename";?>"> 类 别 </option> 
<option value="<?php echo "b.bookname";?>" selected> 书 名 </option> 
<option value="<?php echo "b.author";?>"> 作 者 </option> 
<option value="<?php echo "p.pubname";?>"> 出 版 社 </option> 
<option value="<?php echo "c.name";?>"> 书 架 </option> 
</select> 
<input name-"keyl" type="text" id-"keyl" size="50"> 
«input name-"Submit" type="submit" class-"btn grey" value-"ftif]"» 
«/td» 
«/tr» 
«/table» 
«/form» 
«?php 
include ("conn/conn.php"); 
$query-mysql query ("select b.*,c.name as bookcasename, p. pubname, t . typename 
from tb bookinfo b left join tb bookcase c on b.bookcase-c.id join 
tb publishing p on b.ISBN-p.ISBN join tb booktype t on b.typeid-t.id"); 
$result-mysql fetch array ($query); 
if($result--false)( 
?» 


«table width-"100$" height-"30" border="0" cellpadding-"0" 
cellspacing-"0"» 


«tr» 
«td height-"36" align="center"> 暂 无 图 书信 息 ! </td> 
</tr> 
</table> 

<?php 
f 
elsef 
?> 


«table width="98%" border="1" cellpadding="0" cellspacing="0" 
bordercolor="#FFFFFF" bordercolordark="#D2E3E6" 
bordercolorlight="#FFFFFF"> 

«tr align="center" bgcolor="#D0E9F8"> 

«td width="13s"> 条 形 码 </td> 
«td width="26%"> 图 书 名 称 </td> 
«td width="15%"> 图 书 类 型 </td> 
«td wiqdth="14%"> 出 版 社 </td> 
«td wiqdth="12%"> 书 架 </td> 

</tr> 
«?php 
if($ POST[key1]--"")(| 
do( 

?» 

«tr» 

«td style-"padding:5px;"»&nbsp;«?php echo $result [barcode]; ?»«/td» 
«td style-"padding:5px;"» 

«a href-"book look.php?id-«?php echo $result[id]; ?»"» 

<?php echo $result [bookname];?»«/a»«/td» 
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«td style-"padding:5px;"»&nbsp;«?php echo $result[typename];?»«/td» 
«td style-"padding:5px;"»&nbsp;«?php echo $result[pubname];?»«/td» 
«td style-"padding:5px; "»&nbsp; <?php echo $result [bookcasename] ; ?»«/td» 
«/tr» 
«?php 
)while($result-mysql fetch array ($query)); 
}else{ 
$f=$ POST[f]; 
$keyl=$ POST[keyll; 
$sql-mysql query ("select b.*,c.name as bookcasename,p.pubname,t.typename 
from tb bookinfo b left join tb bookcase c on b.bookcase-c.id join 
tb publishing p on b.ISBN-p.ISBN join tb booktype t on b.typeid-t.id where 
$f like '$$key1$'"); 
Sinfo-mysql fetch array ($sql); 
if(S$info--true)( 
do( 
?» 
«tr» 
// 输 出 符合 查询 条 件 的 记录 
«td style-"padding:5px;"»&nbsp;«?php echo $info[barcode]; ?></td> 
«td style-"padding:5px;"»«a href-"book look.php?id- 
<?php echo $info[id]; ?»"»«?php echo $info[bookname]; ?»«/a»«/td» 
«td style-"padding:5px;"»&nbsp;«?php echo $info[typename]; ?»«/td» 
«td style-"padding:5px;"»&nbsp;«?php echo $info[pubname]; ?»«/td» 
«td style-"padding:5px;"»&nbsp;«?php echo $info[bookcasename]; ?»«/td» 
«/tr» 
«?php 
)while($info-mysql fetch array($sql)); 
Jelse( 
E 
«table width-"100$" height-"30" border="0" cellpadding-"0" cellspacing-"0"» 
«tr» 
«td height-"36" align="center"> 您 检索 的 图 书信 息 不 存在 ， 请 重新 检索 ! </td> 
«/tr» 
«/table» 
«?php 
) 
) 
5 
?» 
«/table»«/td» 
Er» 
«/table»«/td» 
«/tr» 
«/table»«?php include ("copyright.php");?»«/td» 
«/tr» 
«/table» 
«/td» 
«/tr» 
«/table» 
</body> 
</html> 


5.7.4 图 书 借阅 到 期 提醒 
如 果 有 一 些 到 期 的 图 书 需 要 立即 提醒 管理 人 员 , 下 面 通过 一 段 代 码 (bremindphp) 进 行 讲 
——— ————— ————  SÉ—— PHA  —, > 
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解 ， 具 体 如 下 : 


<?php session start();?» 
<html> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
<link href-"CSS/style.css" rel="stylesheet"> 
</head> 
<body> 
<table width="776" border="0" align="center" cellpadding="0" 
cellspacing="0" bgcolor="#FFFFFF" class="tableBorder"> 
«tr» 
«td» 
<?php include ("navigation.php");?» 
«/td» 
«/tr» 
«td bgcolor-"£FFFFFF"» 
«table width-"100$" border="0" cellspacing-"0" cellpadding-"0" 
bgcolor-"£FFFFFE"» 
<tr> 
<td valign="top" bgcolor="#FFFFFF"><table width="99%" height="510" 
border="0" align="center" cellpadding="0" cellspacing="0" 
bgcolor="#FFFFFF" class="tableBorder gray"> 
«tr» 
«td height-"510" valign="top" style-"padding:5px;"»«table width-"98$" 
height-"487" border-"0" cellpadding-"0" cellspacing-"0"» 
«tr» 
«td height-"22" valign="top" class-"word orange"» 
当前 位 置 : 系统 查询 &gt; 借阅 到 期 提醒 &gt;&gt;&gt;c/td» 
«/tr» 
«tr» 
«td align="center" valign="top"> 
<?php 
include ("conn/conn.php"); 
$time=date ("Y-m-d"); 
$sql-mysql query ("select 
book.barcode,book.bookname,reader.barcode as 
readerbarcode,reader.name,borr.borrowTime,borr.backTime,borr.ifback from 
tb bookinfo book join tb borrow as borr on book.id-borr.bookid join 
tb reader as reader on borr.readerid-reader.id where 
borr.backTime«-'$time' and borr.ifback-0"); 
$info-mysql fetch array ($sql); 
if(Sinfo--false)( 
?» 
«table width-"100$" height-"30" border-"0" cellpadding-"0" 
cellspacing-"0"» 
«tr» 
«td height-"36" align="center"> 暂 无 到 期 提醒 信息 ! «/td» 
«/tr» 
«/table» 
«?php 
}elsef 
?» 
«table width-"98$" pborder-"1" cellpadding-"0" cellspacing-"0" 
bordercolor-"£FFFFFF" bordercolordark-"£D2E3E6" 
bordercolorlight-"£$FFFFFF"» 
«tr align="center" bgcolor-"fe3F4F7"» 
«td width="15%"> 图 书 条 形 码 </td> 
«td wiqdth="28%"> 图 书 名 称 </td> 
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«td width="17%"> 读 者 条 形 码 </td> 
«td width="9%"> 读 者 名 称 </td> 
«td width="15$s"> 借 阅 时 间 </td> 
«td width="16%"> 应 还 时 间 </td> 
«/tr» 
<?php 
do{ 
2><tr> 
«td style-"padding:5px;"»&nbsp; 
<?php echo $info[barcode];?»«/td» 
«td style-"padding:5px;"» 
<?php echo $info[bookname];?»«/td» 
«td style="padding: 5px; "»&nbsp; 
<?php echo $info[readerbarcode];?»«/td» 
«td style="padding: 5px; ">&nbsp; 
<?php echo $info[name];?»«/td» 
«td style-"padding:5px;"»&nbsp; 
<?php echo $info[borrowTime];?»«/td» 
«td style-"padding:5px;"»&nbsp; 
<?php echo $info[backTime];?»«/td» 
«/tr» 
«?php 
)while($info-mysql fetch array($sq1l)); 
?> 
</table><?php include ("copyright.php");?»«/td» 


到 今天 为 止 ， 图 书 借阅 模块 设计 完毕 。 此 模块 是 整个 项 目的 最 核心 模块 ， 在 具体 设计 
时 ， 开 始 只 考虑 到 了 几 个 基本 功能 ， 而 没有 考虑 日 常人 性 化 的 功能 。 例 如 ， 到 期 提醒 等 。 
后 来 经 过 几 天 的 摸索 与 修改 ， 系 统 的 功能 变 得 越 来 越 多 ， 也 越 来 越 健全 。 通 过 这 个 模块 ， 
我 深刻 体会 到 健全 项 目的 重要 性 ， 在 日 后 开发 中 一 定 要 更 加 细心 。 


5.8 读者 管理 


结束 图 书 借阅 模块 的 工作 之 后 ， 接 下 来 开始 进入 读者 管理 模块 的 编码 工作 。 该 模块 也 
是 本 系统 的 核心 ， 在 这 一 核心 模块 中 包括 读者 类 型 管理 和 读者 档案 管理 。 此 模块 也 是 本 项 
目的 收尾 模块 ， 功 能 由 同事 D 来 实现 ， 他 需要 完成 以 下 两 方面 的 工作 : 

口 读者 类 型 管理 

口 读者 档案 管理 


5.8.1 读者 类 型 管理 


同样 是 图 书 借阅 人 员 ， 可 能 会 有 学 生 、 有 辅导 员 、 教 授 等 不 同 的 类 型 ， 图 书馆 系统 将 
分 类 管理 这 些 读者 ， 如 图 5-16 所 示 。 
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kttpz// 121. 0-0. V/we/UStushw/readerType-pbp ~ Windovs Internet Explore: 


ES 


LECT o 0 fete pe 


Err 


图 5-16 读者 类 型 的 管理 
下 面 通过 一 段 代 码 readertype.php 进行 讲解 ， 具 体 如 下 : 


<?php session start();?> 
«html» 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
<link href-"CSS/style.css" rel="stylesheet"> 
</head> 
<body> 
<table width="776" border="0" align="center" cellpadding="0" 
cellspacing="0" class="tableBorder"> 
«tr» 
«td» 
<?php include ("navigation.php");?» 
«/td» 
«/tr» 
«td» 
«table width-"100$" border="0" cellspacing-"0" cellpadding-"0"» 
<ET> 
<td valign="top" bgcolor="#FFFFFF"><table width-"99$" height-"510" 
border="0" align="center" cellpadding="0" cellspacing="0" 
bgcolor="#FFFFFF" class="tableBorder gray"> 
LECS 
«td height-"510" valign="top" style="padding: 5px;"><table width="98%" 
height="487" border="0" cellpadding="0" cellspacing="0"> 
«tr» 
«td height-"22" valign="top" class-"word orange"> 当 前 位 置 : 读者 管理 «gt; 
读者 类 型 管理 &gt;&gt;&gt;c/td» 
«/tr» 
«tr» 
«td align="center" valign="top"> 
<?php 
include ("conn/conn.php"); 
$sql-mysql query ("select * from tb readertype"); 
$info-mysql fetch array ($sql); 
if(Sinfo--false)( 
?» 
«table width-"100$" height-"30" border="0" cellpadding-" 
cellspacing-"0"» 


«tr» 
«td height-"36" align="center"> 暂 无 读者 类 型 信息 ! </td> 
«/tr» 
«/table» 
<?php 
}else{ 
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2> 
«table width-"91$" border="0" cellspacing-"0" cellpadding-"0"» 

«tr» 

«td align-"right"» 
<a href="#" onClick-"window.open('readerType add.php','', 
'width-292,height-175') "> 添加 读者 类 型 信息 </a> </td> 
Er 
«/table» 

«table width-"91$" Dborder-"1" cellpadding-"0" cellspacing-"0" 
bordercolor-"£FFFFFF" bordercolordark-"£D2E3E6" 
bordercolorlight-"4FFFFFF"» 

«tr align="center" bgcolor-"£e3F4F7"» 

«td width="35%"> 读 者 类 型 名 称 </td> 
«td width="35$"> 可 借 数量 </td> 
«td width="14$"> 删 除 </td> 

«/tr» 

«?php 
do( 
?» 
«tr» 
«td style-"padding:5px;"»&nbsp;«?php echo $info[name];?»«/td» 
«td style-"padding:5px;"»&nbsp;«?php echo $info[number];?»«/td» 
«td align-"center"»«a href-"readerType del.php?id- 
<?php echo $info[id];?>"> 删 除 </a></td> 
«/tr» 
«?php 
)while(S$info-mysql fetch array($sql)); 
?> 
«/table»«?php include ("copyright.php");?»«/td» 
«/tr»«/table»«/td» </tr> 


«/table» 
</body> 
«/html» 
5.82 读者 档案 管理 
读者 档案 管理 栏目 用 于 管理 读者 的 档案 信息 ， 该 信息 包括 类 型 号 、 姓 名 、 读 者 类 型 、 


证 件 类 型 和 证 件 号 等 ， 如 图 5-17 所 示 。 
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下 面 通过 一 段 代码 (reader.php) 进 行 讲解 ， 具 体 如 下 : 


<?php session start();?> 

«head» 

<link href-"CSS/style.css" rel-"stylesheet"» 
«/head» 


"776" border-"0" align="center" cellpadding-"0" 
cellspacing-"0" class-"tableBorder"» 
«tr» 

«td» 

<?php include ("navigation.php");?» 

«/td» 

«/tr» 

«td» 

«table width-"100$" border="0" cellspacing-"0" 
cellpadding-"0"» 

«tr» 

«td valign="top" bgcolor-"£FFFFFF"»«table width-"99$" height-"510" 
border-"0" align="center" cellpadding-"0" cellspacing-"0" 
gcolor-"£FFFFFF" class-"tableBorder gray"» 

«tr» 

«td height-"510" align="center" valign="top" 
style-"padding:5px;"»«table width-"98$" height-"487" border-"0" 
cellpadding-"0" cellspacing-"0"» 

«tr» 
«td height-"22" valign="top" class-"word orange"> 当 前 位 置 : 读者 
管理 &gt; 读者 档案 管理 &gt; agt; ggt;</td> 
«/tr» 
<Er> 
<td align="center" valign="top"> 
<?php 
include ("conn/conn.php"); 
$sql=mysql query("select r.id,r.barcode,r.name,t.name as 
typename,r.paperType,r.paperNO,r.tel,r.email from tb reader as r join 
(select * from tb readertype) as t on r.typeid-t.id"); 
$info-mysql fetch array($sql); 
if(Sinfo--false)( 
?> «table width-"100$" height-"30" border="0" cellpadding-"0" 
cellspacing-"0"» 
«tr» 
«td height-"36" align="center"> 暂 无 读者 信息 ! </td> 
</tr> 
</table> 
<table width="100%" border= 
cellpadding="0"> 
«tr» 
«td» 
«a href-"reader add.php"> 添 加 读者 信息 </a> «/td» 
«/tr» 
«/table» 
«?php 
}else{ 
?> <table width="100%" border="0" cellspacing="0" cellpadding="0"> 
<tr> 

<td width="87%">&nbsp; </td> 
<td width="13%"> 

«a href-"reader add.php"> 添 加 读者 信息 </a></td> 
</tr> 
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</table> 
«table width-"96$" border="1" cellpadding-"0" cellspacing-"0" 
bordercolor-"£FFFFFF" bordercolordark-"£D2ES3E6" 
bordercolorlight-"4FFFFFFE"» 
«tr align="center" bgcolor-"£e3F4F7"» 
«td width="13%"> 条 形 码 </td> 
«td width="10%"> 姓 名 </td> 
«td width="8%"> 读 者 类 型 </td> 
«td width="10%"> 证 件 类 型 </td> 
«td width="18s"> 证 件 号 码 </td> 
«td width="15%"> 电 话 </td> 
«td width="15%">E-mail</td> 
«td colspan="2"> 操 作 </td> 
«/tr» 
«?php 
do( 
EE 
«td style="padding:5px;"> 
«?php echo $info[barcode];?> «/td» 
«td style-"padding:5px;"» 
«a href-"reader info.php?id-«?php echo 
$info[id]; ?> "><?php echo $info[name];?» </a></td> 
«td style-"padding:5px;"» 
«?php echo $info[typename];?» «/td» 
«td align="center"> 
<?php echo $info[paperType];?» </td> 
«td align="center"> 
<?php echo $info[paperNO];?» </td> 
«td»&nbsp; 
«?php echo $info[tel];?» «/td» 
«td align-"left"»&nbsp; 
«?php echo $info[email];?» «/td» 
«td width-"6$" align="center"> 
«a href-"reader modify.php?id-«?php 
echo $info[iqd];?>"> 修 改 </a></td> 
«td width="5%" align="center"> 
<a href="reader del.php?id=<?php echo 
$info[id];?» "> 删除 </a></td> 
«/tr» 
«?php 
)while(S$info-mysql fetch array($sql)); 
) 
?> </table> 
«/td» 
«/tr» 
</table> 
</td> 
«/tr» 
</table> 
<?php include ("copyright.php");?»«/td» 
</tr> 
</table> 
«/td» 
«/tr» 
«/table» 
</body> 
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今天 同事 D 完成 了 读者 管理 模块 的 编码 工作 。 经 过 简单 调试 之 后 ， 我 们 发 现 读者 管理 
功能 的 设置 非常 必要 ， 是 整个 项 目的 重点 核心 功能 之 一 ， 该 核心 功能 包括 读者 类 型 管理 和 
档案 管理 两 个 方面 。 我 们 在 开发 前 期 只 考虑 到 了 档案 管理 ， 而 没有 考虑 类 型 管理 ， 幸 好 后 
来 逐步 完善 了 该 功能 ， 使 读者 管理 更 为 完善 ， 整 个 项 目的 功能 也 更 加 合理 科学 。 此 时 我 深 
刻 体会 到 后 期 完善 工作 的 重要 性 。 


59 测 iX 


今天 我 们 终于 看 到 了 胜利 的 明光， 最 后 的 项 目测 试 工作 由 我 来 完成 。 调 试 时 一 定 要 细 
心 ， 尽 量 考虑 一 切 可 能 发 生 的 错误 。 在 测试 时 我 将 工程 命名 为 “05tushu”。 


5.9.1 系统 运行 预览 


完成 整个 系统 设计 后 ， 开 始 了 运行 测试 ， 在 浏览 器 中 输入 系统 的 测试 地 址 ， 项 目 运行 
后 的 主 界面 效果 如 图 5-18 所 示 。 


2 Co 85 ET 


sns 。 图 书 条 形 码 图 书 名 浆 
1 — 57654321 历史 是 个 什么 玩意 儿 1-4 


2 — STEIISISI0 1994 B00 
3 123458789 1990, RAMURE 
4 as 我 最 想 要 的 化 权 书 


5-18 ”系统 运行 首页 
借阅 信息 界面 效果 如 图 5-19 所 示 ， 其 他 功能 模块 的 效果 与 此 相似 。 


注意 : 本 项 目的 具体 代码 保存 在 附 赠 光盘 的 “第 5 章 ” 目 录 下 ， 工 程 名 称 为 “05tushu”.。 
请 读者 首先 将 其 复制 到 硬盘 中 ， 去 掉 文 件 的 只 读 属 性 。 
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? hu/bookBorrov. php 
GO Emyn oo vss x ] 
xk Fes zr 00 17w05 R- D 9-omko-OQIAO-" 


dmm: 图 书 们 还 》 图 书信 网 > 


在 调试 的 时 候 我 遇 到 了 一 些 问 题 ， 想 找 同 事 B 请 教 。 没 想到 他 一 口 推荐 了 ， 说 网 上 能 
够 搜索 到 解决 方案 。 


5.9.2 验收 


EN. Rabe 

五 一 要 放假 了 ， 我 们 的 项 目 也 正式 投放 运行 ， 院 方 使 用 后 表示 很 满意 。 特 别 是 界面 的 
设计 ， 让 他 们 眼前 一 亮 ， 这 为 我 们 夺 得 了 很 好 的 头 彩 。 在 后 期 维护 上 ， 我 们 也 安排 了 分 工 ， 
留 下 了 同事 B 的 电话 作为 全 天 候 服务 热线 ， 并 继续 考虑 系统 优化 等 方面 的 问题 。 


510 总 结 


项 目 终 于 完成 了 ， 我 们 开发 的 图 书馆 管理 系统 只 是 一 个 中 小 型 项 目 。 项 目 里 对 信息 的 
分 类 和 对 信息 的 处 理 都 是 十 分 繁琐 的 。 实 际 上 要 开发 出 一 个 兼 具 实用 性 、 系 统 性 ， 可 逐步 
完善 、 逐 步 发 展 的 图 书 管 系统 是 十 分 困难 的 。 在 开发 图 书馆 过 程 中 ， 我 总 结 出 以 下 3 条 
经 验 。 

D) 信息 繁多 ， 分 类 编写 

在 开发 的 时 候 ， 开 发 者 一 定 要 将 这 个 系统 的 需求 分 析 各 个 模块 的 关系 理 清 ， 然 后 开发 
相 呼 应 的 数据 库 ， 编 写 出 公共 部 分 ， 一 个 模块 一 个 模块 的 编写 ， 这 样 既 可 方便 调试 ， 又 能 
加 快 开 发 速度 ， 让 结构 也 变 得 十 分 清晰 。 

2) 数据 库 的 周密 设计 
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因为 在 数据 库 中 需要 存储 规模 庞大 结构 复杂 的 图 书信 息 ， 所 以 数据 库 设计 至 关 重 要 。 
如 果 对 数据 库 不 熟悉 ， 很 有 可 能 设计 的 数据 库 只 够 5 台电 脑 同时 访问 ， 别 人 能 做 到 50 台电 
脑 同 时 访问 ， 而 且 功 能 一 模 一 样 ， 所 以 在 数据 库 设计 时 ， 一 定 要 反复 推 项 ， 理 清关 系 ， 建 
立 合理 的 数据 库 表 ， 方 便 后 来 者 开发 。 

3) 数据 库 备份 很 有 必要 

这 个 系统 的 开发 中 ， 也 并 不 是 十 分 的 完美 ， 这 是 图 书馆 系统 ， 固 然 说 数据 库 信息 十 分 
重要 ， 对 于 数据 库 的 信息 ， 系 统 后台 应 该 有 备份 功能 和 还 原 功能 ， 这 样 方便 管理 者 管理 ， 
即使 黑客 或 者 病毒 入 侵 ， 也 能 将 风险 将 到 最 低 ， 从 而 防止 数据 库 的 大 量 丢 失 。 

技术 总 结 完 之 后 ， 再 总 结 点 工作 中 的 体会 。 想 起 了 过 去 一 段 日 子 和 同事 们 的 朝夕 相处 ， 
有 了 两 件 事 给 我 留 下 了 深刻 的 印象 。 

1) 开发 部 和 产品 部 的 关系 

产品 部 SEC 负责 向 我 们 程序 员 传递 客户 需求 ， 并 递交 书面 材料 。 在 开发 阶段 ， 我 们 问 
过 几 次 有 客户 是 否 有 新 的 需求 ， 他 只 说 需要 增加 用 户 登录 验证 。 我 们 添加 此 功能 后 ， 以 为 
整个 项 目 完成 了 。 结 果 客 户 看 后 ， 问 为 什么 没有 绘制 Bezier 的 功能 。 问 的 我 们 云 里 雾 里 的 
我 们 根本 没 听 说 要 添加 这 个 模块 。 问 SEC， 他 说 告诉 过 我 们 开发 部 了 。 最 后 我 们 只 能 无 奈 
的 加 班 到 凌晨 ， 才 完成 了 客户 的 需求 。 

事后 ， 整 个 项 目 进展 顺利 ， 我 们 也 就 忘记 了 这 件 不 愉快 的 事情 。 庆 功 会 上 ，DP 让 我 们 
牢记 书面 材料 的 重要 性 ， 特 意 嘱 只 在 和 产品 部 沟通 时 ， 不 管 什么 业务 都 要 有 书面 材料 明细 
证 明 。 这 也 难怪 ， 在 软件 公司 内 ， 我 们 开发 部 和 产品 部 的 关系 最 密切 ， 两 部 门 间 业 务 合作 
的 频率 高 。 之 间 产 生 各 种 问题 也 在 所 难免 ， 不 管 是 员工 办 事 效 率 低 的 原因 ， 还 是 部 门 之 间 
斗气 的 原因 ， 总 之 发 生 摩擦 很 正常 。 

2) 教会 徒弟 ， 饿 死 师傅 。 

办 公 室内 以 供 我 们 3 个 人 ， 朝 夕 相处， 按理 说 应 该 亲密 无 间 。 原 来 我 也 是 这 么 认为 的 
因为 我 们 有 机 会 就 出 去 聚会 FB， 谈 天 说 地 ， 也 很 恢 意 。 但 是 在 这 个 项 目 中 ， 付 鹏 不 愿意 指 
点 我 调试 的 知识 ， 很 出 乎 我 意料 。 现 在 想来 也 很 正常 ， 同 事 之 间 关系 再 铁 也 是 同事 ， 同 事 
之 间 本 来 就 存在 着 竞争 关系 。 他 如 果 教 会 了 你 ， 他 还 有 什么 值得 炫 炉 的 吗 ? 你 会 了 就 说 明 
你 能 替代 他 了 ， 所 以 他 不 会 轻易 传授 给 你 技术 。 


典型 企业 网 站 (@ 


企业 网 站 就 是 企业 在 互联 网 上 进行 网 络 建设 和 形象 
宣传 的 平台 。 企 业 网 站 就 相当 于 一 个 企业 的 网 络 名 片 ， 他 
不 仅 对 企业 的 形象 是 一 个 良好 的 宣传 ， 还 可 以 辅助 企业 产 
品 的 销售 ， 甚 至 可 以 通过 网 络 直接 销售 产品 。 另 外 ， 企 业 
网 站 不 仅 会 给 企业 带 来 部 分 客户 ， 还 可 以 实现 招聘 、 收 发 
邮件 等 功能 。 

在 本 章 的 内 容 中 ， 将 详细 讲解 中 小 型 企业 门户 网 站 ， 
用 它 实 现 一 个 企业 门户 网 站 的 网 络 功能 ， 读 者 学 习 本 章 ， 
将 详细 地 了 解 一 个 企业 门户 网 站 的 开发 流程 ， 这 将 为 以 后 
深入 地 学 习 打 下 坚实 的 基础 。 
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6.1 书 到 用 时 方 恨 少 


在 学 校 的 时 候 ， 什 么 项 目 都 没有 机 会 去 接触 ， 因 缺乏 实际 经 验 而 困惑 ， 走 入 职场 ， 面 
对 的 项 目 越 来 越 多 ， 有 了 一 种 “ 书 到 用 时 方 恨 少 ”的 感觉 ， 大 的 项 目 好 像 不 适合 我 这 种 刚 
毕业 的 学 生 。 但 是 小 项 目 还 是 要 做 ， 可 以 多 学 点 东西 ， 积 累 开发 经 验 。 


6.1.1 项 目 来 源 


毕业 几 年 了 ， 我 由 一 个 职场 菜鸟 逐 渐 成 为 了 一 个 有 些许 经 验 的 程序 员 。 因 为 我 的 杰出 
表现 ， 上 个 月 刚刚 被 任命 为 开发 组 组 长 。 下 午 我 接 到 了 一 个 新 的 项 目 ， 为 省 内 一 家 知名 家 
具 公 司 开 发 一 个 企业 网 站 。 这 是 好 朋友 介绍 的 ， 心 里 有 了 一 丝 丝 暖 意 ， 减 轻 了 些 上 次 请 教 
未 果 的 伤心 ， 赶 紧 投 入 到 了 项 目 中 。 


6.1.2 ”组建 团队 


这 几 天 天 天 下 雨 ， 并 没有 是 因为 夏天 而 酷热 。 我 怀 着 愉悦 的 心情 回 到 公司 ， 组 建 了 一 
个 小 团队 。 团 队 成 员 如 下 。 

同事 A: 

来 自 三 峡 的 一 个 农村 ， 据 他 说 是 刘备 兵 败 的 地 方 ， 叫 什么 奉节 来 着 ， 他 刚 来 公司 不 久 ， 
对 公司 也 不 是 十 分 了 解 。 此 人 程序 学 得 不 怎么 好 ， 但 其 策划 能 力 、 鬼 点 子 倒 一 套 一 套 的 。 

任务 : 负责 项 目 规划 ， 撰 写 系统 设计 规划 书 。 

同事 B: 

他 是 好 朋友 的 弟弟 ， 比 我 小 一 级 ， 深 受 哥 哥 的 影响 ， 对 数据 库 有 一 种 特殊 的 感觉 ， 因 
为 好 友 介 绍 项 目的 关系 ， 所 以 老总 也 让 他 来 公司 实习 锻炼 。 

任务 : 负责 需求 分 析 和 数据 库 设 计 。 

同事 C: 

是 一 个 运动 狂人 人， 喜欢 惊险 刺激 的 户外 运动 ， 常 常 去 奥 体 中 心 打 球 ， 自 己 参 加 了 一 个 
足球 协会 ， 每 周 都 会 去 踢 球 。 

任务 : 完成 前 台 设计 和 部 分 其 他 功能 设计 。 

我 : 
我 因为 表现 突出 ， 升 职 了 ， 由 一 个 小 职员 升级 为 项 目 组 组 长 。 
任务 : 负责 系统 整体 框架 设计 ， 并 协调 项 目 中 各 个 模块 的 进展 。 
具体 职能 结构 如 图 6-1 所 示 。 
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同事 A 同事 C 
项 目 规划 前 台 设计 
撰写 策划 书 部 分 功能 设计 


同事 B 
需求 设计 
数据 库 设计 


图 6-1 职能 结构 图 
整个 项 目的 具体 操作 流程 是 : 项 目 规划 一 数据 库 设 计 一 框架 设计 一 前 台 设计 、 新 闻 发 
布 、 留 言 反馈 。 


6.1.3 小 会 议 


| 2008355 29 日 ， 哺 ， 动 员 会 议 


我 刚 升 为 项 目 组 组 长 就 召开 了 会 议 ， 满 足 了 一 下 自己 的 虚荣 心 。 在 会 议 上 我 们 对 整个 
项 目 进行 了 规划 ， 我 们 一 致 认为 此 项 目 可 以 分 为 数据 库 建立 、 维护 以 及 前 人 程序 的 开发 等 
几 个 方面 。 前 台 程 序 主要 是 将 数据 库 的 信息 展示 出 来 ， 包 括 商品 信息 和 新 闻 信 息 。 后 台 程 
序 是 用 户 对 前 台 进 行 管理 ， 用 于 对 系统 的 设置 和 对 信息 的 发 布 和 管理 。 

最 后 我 做 了 一 个 简单 的 总 结 : “要 开发 一 个 企业 门户 网 站 ， 首 先 需 要 进行 系统 需求 分 
析 和 总 体 设 计 ， 分 析 系 统 的 使 用 对 象 和 用 户 需 求 ， 设 计 系 统 的 体系 结构 和 数据 库 表 结 构 ， 
决定 使 用 的 开发 工具 和 后 台数 据 库 ， 规 划 项 目的 开发 进度 等 。” 

大 家 一 致 提议 同事 A 尽快 作出 规划 书 ， 后 续 工 作 将 以 规划 书 为 基础 进行 扩展 。 


6.2 系统 概述 和 总 体 设计 
Fumo: 6910. 04a 


今天 是 6 月 1 日， 国际 儿童 节 。 在 这 个 祖国 花灯 欢 庆 的 日 子 里 ， 同 事 A 做 出 了 项 目 规 
划 书 ， 整 个 规划 书 分 为 以 下 两 个 部 分 : 

ü 系统 需求 分 析 

O 系统 运行 流程 
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6.2.1 系统 需求 分 析 

企业 门户 管理 系统 的 用 户主 要 是 客户 和 员工 ， 具 体 功能 如 下 。 

1. 新 闻 中 心 

这 是 一 个 企业 门户 网 站 ， 发 布 新 闻 分 为 企业 新 闻 和 行业 新 闻 。 

2. 产品 中 心 

产品 中 心 是 用 来 发 布 企业 内 产品 的 一 个 栏目 ， 用 户 可 以 根据 需求 将 产品 分 成 不 同 的 类 
别 ， 用 于 介绍 其 信息 。 

3. 下 载 中 心 

这 是 一 个 供用 户 下 载 的 频道 ， 在 这 个 栏目 里 ， 用 户 可 以 将 许多 文件 提供 在 里 面 供 浏览 
者 下 载 ， 如 产品 注意 事项 等 信息 。 

4. 常见 问答 

此 栏目 是 用 来 与 浏览 者 客户 交流 的 频道 ， 客 户 可 以 在 这 个 栏目 中 留言 ， 如 意见 反馈 等 
-系列 信息 内 容 。 

5. 管理 模块 


管理 模块 是 对 整个 前 台 的 模块 进行 管理 和 内 容 填充 。 
根据 需求 分 析 中 总 结 的 用 户 需 求 设计 系统 的 体系 结构 ， 如 图 6-2 所 示 。 


"YE 


62 ”系统 模块 示意 图 


62.2 ”系统 运行 流程 
在 此 模拟 了 系统 的 运行 情景 : 运行 系统 后 ， 如 果 是 超级 管理 者 ， 用 户 可 以 对 系统 进行 
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管理 ， 进 入 管理 页 ， 输 入 用 户 名 和 密码 可 以 对 各 个 栏目 和 板块 进行 添加 内 容 的 操作 ， 如 
图 6-3 所 示 。 


E 堆 岂 符 网 站 管理 系统 后 台 登 录 - Windows Internet Explorer. IEIEI 7] 


OO [E 551270037. ds X ||P aver 5- 


@ Internet | 保护 模式 : 禁用 


图 6-3 系统 管理 页 


6.3 数 据 库 


同事 A 结束 了 规划 书 和 系统 分 析 的 工作 ， 我 就 让 同事 B 马上 进入 数据 库 的 设计 阶段 。 
几乎 所 有 的 动态 网 站 都 是 基于 数据 库 的 ， 数 据 库 的 合理 性 关系 到 了 整个 系统 的 运行 效率 
所 以 我 很 怀疑 同事 B 是 否 有 他 哥哥 的 水 平 。 


6.3.0. 数据 库 设计 


具体 的 数据 库 设计 ， 同 事 B 参考 了 同事 A 的 需求 分 析 。 由 需求 分 析 的 规划 可 知 整个 项 
目 对 象 有 17 种 信息 ， 所 以 对 应 的 数据 库 也 需要 包含 这 17 种 信息 ， 从 而 系统 需要 包含 17 个 
数据 库 表 ， 下 面 只 对 重要 的 7 个 数据 库 信 息 表 进 行 详 细 讲 解 。 

(1) 管理 员 信 息 表 (06n_admin table): 这 个 表 主 要 是 用 来 存储 管理 员 的 用 户 名 、 密 码 和 
其 他 信息 的 表 ， 如 表 6-1 所 示 。 

(2) 下 载 信 息 表 (06n_admin table): 这 个 表 主 要 是 用 来 存储 下 载 的 一 些 资料 ， 如 表 6-2 
所 示 。 

(3) 反馈 信息 表 (06n_fdparameter): 这 个 表 主要 是 用 来 存储 反馈 的 信息 ， 如 表 6-3 所 示 。 

(4) 图 片 信息 表 (06n_img): 这 个 表 主 要 是 用 来 图 片 的 一 些 资料 ， 如 表 6-4 所 示 。 

(5) 招聘 信息 表 (06n job): 这 个 表 主要 是 用 来 存储 招聘 的 一 些 资料 ， 如 表 6-5 所 示 。 

(6) 友情 链接 信息 表 (06n_ link): 这 个 表 主 要 是 用 来 存储 友情 链接 的 一 些 资料 ， 如 表 6-6 
所 示 。 

(7) 新 闻 信 息 表 (06n_news): 这 个 表 主 要 是 用 来 存储 新 闻 的 一 些 资料 ， 如 图 6-7 所 示 。 


和 和 和 和 和 >B 


深入 体验 PHP 项 目 开发 


字段 大 型 
r1 int(11) 
admin type text 
admin id charf15) 
admin pass charíé4) 
admin name varchar(30) 
admin sex njntCt) 
admin tel warchar(20) 
admin mobile. varchar(20) 
admin email varchar(150) 
admin qq varchar(12) 
admin msn varchar(40) 
admin taobao varchar(40) 
admin introduction — text 
admin login iman) 


表 6-1 管理 员 信息 表 


Et nu Y 要 外 
auto_increment 
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X62 下载 信息 表 


整理 属性 nu RU ki 
auto_increment 


int11) 
int11) 
int(11) 

int(1) 
varchar(300) 
varchar(100) 
int(1) 

int(11) 


表 6-3 反馈 信息 表 


类 型 
int(11) 


uff8 general ci 
wif8 general ci 


uff general ci 
utf&, general ci 
uff. general. ci 
wf general ci 
uff8 general ci 
wif general ci 
utf&, general ci 


warchar255) uff8 general ci 
varchar255) utf& general ci 


int(11) 
int(11) 
int) 
int(11) 
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m 
m 
加 
回 


aag 


a 


B 
m 
如 
d 
m 
加 
名 
m 
m 
m 
m 
mm 
m 
m 
Án 
m 
B 


Ll 
mxm 
B»xt 
E727 xE 
mxm 
moxm 
mxm 
m»xm 
2xm 
m^xm 
mxm 
moxm 
m»xm 
mB»xm 
mxm 
moxmu 
Ex E 
m»xm 
m»xm 
m»xm 
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E 
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varchar(300) utf8 general ci 
varchar300) uff general ci 


varchar(200) utf& general ci 
warchar200) utfà general ci 
varchar(200) utf8 general ci 
warchar(200) uff general ci 
varchar(200) uff8 general ci 


表 6-5 招聘 信息 表 


E 
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类 型 整理 Ett n SS 
int11) Lj 
warchar(200) ffe general ci 是 NULL 
varchar(200) utf8 general ci 是 nuu 
int(11) 是 0 
Varchar(200) uff general ci 是 NULL 
warchar(200) wtf8 general ci 是 NULL 
varchar(200) ul8_general_ol 是 NULL 
varchar(200) utf8 general ci 是 nuu 
date 是 nu 
int(11) 是 NULL 
longtext wtfé general, ci 是 nu 
longtex —— uffó general ci 是 NULL 


表 6-6 ”友情 链接 信息 表 


类 型 整理 属性 Nul RU 
int(11) Ej 
warchar255) uff general ci 是 nuu 
varchar(255) utf8_general_ci * NULL 
warchar(255) utf8 general ci 是 nuu 
varchar(255) uff general ci & nuu 
int11) | 各 共 2 
varchar(255) uff general ci 是 NULL 
varchar255) utf8 general ci 是 nuu 
varchar(255) utf8 general ci 是 nuu 
int(t1) 是 0 
int(11) 是 0 
imt) 是 0 
datetime 是 NULL 
warchar255) uff general ci 是 nuu 
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auto increment 


auto increment 
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R67 新 闻 信息 表 


字段 大 型 m LN M Ll 

u iman) Ei auto_increment 
€. fitle varchar200) utfe general ci 是 nuu 
e title varchar(200) utf8 general ci 是 NULL 
€ keywords — varcha(200) uff general ci 是 NULL 
e keywords 。 varchar200) uff8 general ci 是 nu 
c descripüon text utfs general ci 是 AULL 
e_description text uff general ci 是 nu 
c content longtext ui general ci 是 AULL 
econtent 。 longer ule_general_o 是 AULL 
class1 iT 是 0 
class2 iman) 是 0 
class? iT 是 0 
img ok inttt) 是 0 
imgur varchar(300) utf8 general cdi 是 nu 
imguris varchar(300) utf8_general_ci 是 AULL 
com ok int(1) 是 o 
issue varchar(100) utf8 general ci 是 nu 
hits int 人 是 0 
updatetime datetime 是 NULL 
addtime datetime 是 AULL 


注意 : 为 了 节省 本 书 篇 幅 ， 在 此 只 将 重要 的 7 种 数据 库 表 的 设计 结构 进行 了 讲解 。 至 于 其 
他 数据 库 表 的 结构 ， 建 议 读者 参考 本 书 配套 光盘 中 的 数据 库 文件 ， 相 信 一 读 便 懂 。 


6.3.2 ”数据 库 编程 


当 用 户 建立 完 数据 库 ， 要 为 程序 员 编写 程序 配置 页 面 ， 供 程序 调用 。 下 面 将 通过 一 段 
代码 进行 讲解 ， 其 代码 (config_db.php) 如 下 : 


<?php 
/* 
con db host = "localhost" // 数 据 库 地 址 
con db id = "root"// 数 据 库 用 户 名 
con db pass- "1234"// 数 据 库 密码 
con db name = "06news"// 数 据 库 名 称 
tablepre = "06n_"// 数 据 库 表 前 组 
db charset = "utf8";// 数 据 库 字符 集 

?> 
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今天 同事 B 完成 了 数据 库 设计 的 全 部 工作 。 看 着 他 设计 的 数据 库 ， 我 不 禁 赞叹 起 来 ， 
真有 他 哥 的 风范 啊 ， 各 个 数据 库 表 的 功能 一 目 了 然 ， 设 计 合理 ， 我 相信 运用 到 此 项 目 后 ， 
一 定 会 大 大 提高 仿真 这 个 站 点 的 效率 。 其 实 官方 门户 网 站 是 必 不 可 少 的 ， 很 多 公司 为 了 塑 
造 企业 形象 ， 都 开发 自己 的 网 站 ， 向 外 界 展示 自己 的 软 实力 ， 数 据 库 设计 和 数据 库 编程 是 
开发 网 站 的 必 备 核心 。 
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6.4 系统 框架 设计 


o. saM 


今天 天 气 有 点 阴 ， 在 这 个 略 显 阴 暗 的 天 气 里 我 们 开始 了 接 下 来 的 工作 一 一 系统 框架 设 
计 。 此 阶段 的 任务 是 由 我 来 完成 的 ， 我 根据 前 面 的 规划 书 、 系 统 分 析 和 数据 库 资料 ， 经 过 
仔细 权衡 之 后 ， 想 出 了 一 个 完整 的 方案 。 


6.4.1 新 闻 功 能 


新 闻 功 能 是 企业 门户 网 站 系统 的 重点 核心 之 一 ， 主 要 用 于 发 布 企 业 新 闻 和 行业 新 闻 ， 
如 图 6-4 所 示 。 


了 相交 Windomn Internet Erplorer 


EO- 127001 -[4]x TR Pp- 
dy Bw R-H-cw 2-5-0 
Qima 

| 


Quiere rate un ET 
图 6-4 新 闻 功 能 

下 面 通过 一 段 代 码 进行 讲解 ， 其 代码 如 下 : 

«?php 


require once '../include/common.inc.php'; // 连 接 数据 库 
$rooturl-".."; 


$css url-"../templates/".$met skin user."/css/";// 指 定 CSS 目录 
$img url-"../templates/".$met skin user."/images";// 指 定 图 片 位 置 
$navurl-($rooturl—-"..")?$rooturl."/":""; 

$classl info-$db-»get one("select * from $met column where id-'$classl1'"); 

if(!classl info)( 

okinfo('../',$1ang[noid]); 

}; 

$serch sql-" where classl=$class1 ";// 搜 集 数据 

if($class2)$serch sql .= " and class2-$class2"; 

if($class3)$serch sql .= " and class3-$class3"; 

$order sql-list order($classl info[list order]); 
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if($search == "detail search") { // 详 细 数 据 
if($c title) ( $serch sql -= " and c title like '$$c title$' "; } 
if($e title) ( $serch sql .= " and e title like '$$e title$' "; } 
$total count = $db-»counter($met news, "$serch sql", "*"); 
) else ( 


$total count = $db-»counter($met news, "$serch sql", "*"); 
ji 


require once '../include/pager.class.php'; 
/// 调 入 页 面 

$page = (int)$page; 

// 页 码 


if($page input) {$page=$page input;} 
$list num-$met news list; 
/处 理 新 闻 列 表 
$rowset = new Pager($total count,$1ist num, Spage) 7 
$from record = $rowset-» offset(); 
// 表 单 档案 处 理 
$query = "SELECT * FROM $met news $serch sql $order sql LIMI 
$from record, $list num"; 
$result = $db-»query ($query); 
while($list- $db-»fetch array ($result)){ 
$urll c-"shownews.php?id-".$1ist[id]; 
// 显 示 新 闻 ID 列表 
$url2 c-"shownews".$1list[id].".htm"; 
$urll e-"shownews.php?en-en&id-".$1list[id]; 
$url2 e-"shownews".$1ist[id]." en.htm"; 
$list[c url]-$met webhtm?$url2 c:$urll c; 
$list[e url]-$met webhtm?$url2 e:$urll e; 


if(Slist[new ok] == 1)$news list new[]-$1list; 
if(Slist[com ok] == 1)$news list com[]-$1list; 
// 新 闻 列表 


$news list[]-$1ist; 

) 
$c page list = 
$rowset-»link("news.php?classl-$classl&class2-$class2&class3-$class3&sea 
rch-$search&c title-$c title&page-"); 
$e page list = 
$rowset-»link("news.php?en-en&classl-$classl&class2-$class2&class3 
-$class3&search-$search&e title-e title&page-"); 


// 处 理 页 面 信息 

require once '../include/head.php'; 

// 调 入 页 面 

$class info[e description]-$classl info[e description]; 
// 描 述 英文 信息 

$class info[c description]-$classl info[c description]; 
// 描 述 中 文 信息 

$class info[e keywords]-$classl info[e keywords]; 

// 英 文 关键 字 

$class info[c keywords]-$classl info[c keywords]; 

// 中 文 关键 字 

$class info[e name]=$classl info[e name]; 

// 英 文 名 

$class info[c name]-$class1 info[c name]; 

/7 中 文 名 


$nav x[c name]-$class1 info[c name]; 
$nav x[e name]-$class1 info[e name]; 
if($class2!-"")[(// 
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foreach ($nav list2[$classl] as $key-»$val) {// 搜 索 

if ($class2==$val[id]){ 

$class2 info=$val; 

$class info[e description]=$class2 info[e description]; 


// 英 文 产品 描述 

$class info[c description]-$class2 info[c description]; 

// 中 文 产品 描述 

$class info[e keywords]=$class2 info[e keywords]; 

// 英 文 关键 字 

$class info[c keywords]=$class2 info[c keywords]; 

/ /中文 关键 字 

$class info[e name]-$class2 info[e name]."--".$classl info[e name]; 
// 英 文 名 

$class info[c name]-$class2 info[c name]."--".$classl info[c name]; 
IPA 


$nav x[c name]=$class1 info[c name]." > ".$class2 info[c name]; 
$nav x[e name]-$classl info[e name]." > ".$class2 info[e name]; 
} 

} 

} 

if(Sclass3!-"")( // 获 取信 息 列表 

foreach ($nav list3[$class2] as $key=>$val){ 

if ($class3==$val[id]){ 

$class3 info=$val; 

$class info[e description]-$class3 info[e description];// 英 文 描述 
$class_info[c description]=$class3 info[c description];// 中 文 描述 
$class info[e keywords]=$class3 info[e keywords]; 

// 英 文 关键 字 

$class info[c keywords]-$class3 info[c keywords]; 

// 中 文 关键 字 

$class info[e name]=$class3 info[e name]. 

"—".$class2 info[e name]."--". 

$classl info[e name];// 英 文 名 

$class info[c name]-$class3 info[c name]. 

"-—-".$class2 info[c name]."--". 

$classl info[c name];//" 3X 4 

$nav x[c name]-$class1 info[c name]." > ".$class2 info[c name]." > 
".$class3 info[c name];//'P3X 4 

$nav x[e name]-$class1 info[e name]." > ".$class2 info[e name]." > 
".$class3 info[e name]; .//JXX 44 

3 

if($en--"en")( // 获 取 新 闻 信息 列表 

$show[e description]-$class info[e description]? 

$class info[e descriptio 

n]:$met e keywords; //J& 3C 

$show[e keywords]-$class info[e keywords]? 

$class info[e keywords]:$met e 

keywords; 

$e title keywords-$class info[e name]."--".$e title keywords; 
include template('e news'); 

H 

else( 

$show[c description]-$class info[c description]? 

$class info[c descriptio 

n]:$met c keywords;/ /中 文 描述 

$show[c keywords]-$class info[c keywords]? 

$clas s info [c keywords]:$met c 
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keywords; / /中文 关键 字 
$c title keywords-$class info[c name]."--". 
$c title keywords; 
include template ('news'); 
H 
footer(); 
?> 


642 图片 功能 


图 片 展示 功能 是 企业 门户 网 站 系统 的 重要 内 容 之 一 ， 用 它 来 展示 一 些 近 期 较为 重要 的 
信息 ， 如 图 6-5 所 示 。 
es AER (AS -FRED HRI - Windows Intemet Explorer ler 
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图 6-5 图 片 中 心 
下 面 通过 一 段 代码 进行 讲解 ， 其 代码 如 下 : 
<?php 
// 获 取 数据 库 连 接 等 配置 信息 
require once '../include/common.inc.php'; 
// 调 入 数据 连接 信息 
$rooturl-".."; 
$css url-"../templates/".$met skin user."/css/"; 
// 模 板 设置 
$img url-"../templates/".$met skin 1 
$navurl-($rooturl--"..")?$rooturl." 
// 获 取 图 片 信息 
$query = "SELECT * FROM $met parameter where type-'5' and use ok-'1' order 
by no order"; 
$result = $db-»query ($query); 
while ($list= $db->fetch array ($result) ) { 
if($list[maxsize]--200)$img para200[]=$list;// 最 大 尺寸 


."/images";// 图 片 信息 
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$img para[]-$1list; 
5 
Simg-$db-»get one ("select * from $met img where id-'$id'"); 
// 根 据 id 号 获取 一 张 图 片 
if(!Simg)( 
okinfo('../',$1ang[noid]); 
bi 
$img[c content]=contentshow ($img[c content]);// 中 文 内 容 显 示 
$img[e_content]=contentshow ($img[e_content]);// 英 文 内 容 显 示 
$classi-$img[classl]; 
$class2-$img[class2]; 
$class3-$img[class3]; 
$classl info-$db-»get one("select * from $met column where 
id='$classl'") 7;// 显 示 内 容 信息 
if(!classl info)( 
okinfo('../',$1ang[noid]); 
) 
$serch sql=" where classl-$classl "; 
if($class2)$serch sql .= " and class2=$class2";// 搜 索 信 息 
if($class3)$serch sql .= " and class3-$class3"; 
if($search == "detail search") (  // 删 除 搜索 信息 
if($c title) ( $serch sql .= " and c title like '$$c title$' "; } 
if($e title) ( $serch sql .= " and e title like '$$e title$' "; } 


) 

$order sql-list order($classl info[list order]);// 顺 序 
$query = "SELECT * FROM $met img $serch sql $order sql"; 
$result = $db-»query ($query); 

while($list- $db-»fetch array ($result)){ 

$urll c-"showimg.php?id-".$1ist[id]; 

$url2 c-"showimg".$list[id].".htm"; 

$urll e-"showimg.php?en-en&id-".$1list[id]; 

$url2 e-"showimg".$1list[id]." en.htm"; 

$list[c url]-$met webhtm?$url2 c:$urll c; 

$list[e url]-$met webhtm?$url2 e:$urll e; 
if($list[new ok] == 1)$img list new[]-$1ist; 

if ($list[com ok] == 1)$img list com[]-$1ist; 

$img list[]-$1ist; 


} 

// 获 取 网 页 的 头 部 信息 

require once '../include/head.php'; 

$nav x[c name]-$class1 info[c name]; 

$nav x[e name]-$classl info[e name]; 

Af($class2!-"")( 

foreach ($nav list2[$classl] as $key-»$val)( 
if($class2--$val[id])t 
$class2 info-$val; 
$nav x[c name]-$class1 info[c name]." > ".$class2 info[c name]; 
$nav x[e name]-$class1 info[e name]." > ".$class2 info[e name]; 
3 
if($class3!-"")( 
foreach ($nav list3[$class2] as $key-»$val)( 
if($class3--$val[id])(t 
$class3 info-$val; 
$nav x[c name]-$classl info [c_name]." >" -$class2 info [c name]." » 
".$Class3 info[c name]; 
$nav x[e name]-$class1 info[e name]." > ".$class2 info[e name]." > 
".$Class3 info[e name]; 
i 
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// 获 取 图 片 英 文 信息 

if ($en=="en"){ 

$show[e description]-$img[e description]?$img[e description] :Smet e 
keywords; 

$show [e keywords] -$img [e keywords]?$ img [e keywords]: $met e keywords Bg 
$e title keywords-$img[e title]."--".$e title keywords; 

$nav x[e name]-$nav x[e name]." > ".$img[e title]; 

include template('e showimg'); 

}else{ 

$show[c description]-$img[c description]?$img[c description] :Smet c 
keywords; 

$show[c keywords]=$img[c keywords]?$img[c keywords] :Smet c keywords; 
$c title keywords-Simg[c title]."--".$c title keywords; 

$nav x[c name]-$nav x[c name]." > ".$img[c title]; 

include template ('showimg'); 

} 

footer(); 

red 


6.4.3 ”在 线 反馈 功能 


在 这 个 系统 信息 里 ， 有 一 个 特别 重要 的 功能 ， 此 功能 是 为 了 提高 浏览 者 向 公司 反馈 问 
题 的 一 个 栏目 ， 效 果 如 图 6-6 所 示 。 
B WIRES IERI TERAMO 技术 支持 - Windows Intenet Explorer 
QGU-. http://127.0.0.1/web/06news/feedback/inde» ~ | 好 |X [a 
- Tle- 


dX Bassum m 
4 


首页 mE 


mimm E [s] ` 
GREE . 
姓名 * 
职务 
pee . 


电话 


LE: lr 


提交 信息 。 重新 填写 


@ Internet | 保护 模式 SA fa * R100% ~ 


图 6-6 ”信息 反馈 功能 
下 面 通过 一 段 代 码 进行 讲解 ， 其 代码 (feedback/index.php) 如 下 : 
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«?php 

// 获 取 数 据 库 信息 

require once '../include/common.inc.php"';// 调 入 网 页 文件 
$settings = parse ini file('config.inc.php');// 配 置 文件 
@extract ($settings); 

$rooturi=".."; 

$css url-"../templates/".$met skin user."/css/"; 

$img url-"../templates/".$met skin user."/images"; 
$navurl-($rooturl--"..")?$rooturl."/":""; 

$fromurl-$ SERVER['HTTP REFERER']; 

Sip-getenv('REMOTE ADDR'); 

if ($title==""){ 

$navtitle- ($en--"en") ?"FeedBack":" 咨 询 反 馈 "; 
$title=$navtitle; 

) 

else( 

$c navtitlel-"[".$title."]fi ARH"; 

$e navtitlel-"[".$title."]FeedBack"; 

$navtitle- ($en=: n")?$e navtitlel:$c navtitlel; 

} 

if($action--"add")( 

$addtime-$m now date; 

$ipok-$db-»get one("select * from $met feedback where ip-'$ip' order by 
addtime desc"); 

$timel = strtotime (Sipok[addtime]);// 添 加 时 间 

$time2 = strtotime (Sm now date) ;添加 日 期 

$timeok= (float) ($time2-$timel); 

// 提 示 信 息 

if ($timeok<=$met fd time)( 

$c fq time=" 请 不 要 在 " .$met fd time." 秒 内 重复 提交 信息 ， 谢 谢 合作 ! "n; 


$e fd time-"Please do not send information again in".Smet fd time."second! "; 


$fd time-(Sen--"en")?$e fd time:$c fd time; 
okinfo('javascript:history.back();',$fd time); 
) 


$fdstr = $met fd word; 
$fdarray-explode ("|",$fdstr) 7;// 修 改 数组 
$fdarrayno-count ($fdarray) ;// 立 体 阵列 
$fdok-false; 

for ($j=1; $j<=20;$j++) ( 
$para-"para".$j; 
$content-$content."-".$$para; 

} 

for ($i=0;$i<$fdarrayno; $i++) { 

if (strstr ($content, $fdarray[$il))( 
$fdok=true; 

$fd word=$fdarray[$i]; 

break; 

} 

} 


$c fd word=" 反 馈 信息 中 不 能 包含 [" .$fd word."]! "; 

$e fd word-"[".$fd word."] is not permited to send! "; 

$fd word-($en--"en")?$e fd word:$c fd word; 
if(Sfdok--true)okinfo('javascript:history.back();',$fd word); 
if($met fd type--0 or $met fd type--2)( 
$from-$met fd usename; 


————————— ——P———————— —— Dd 213. 
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Sfromname-$met fd fromname; 
$to-$met fd to; 
$usename-$met fd usename; 
$usepassword-$met fd password; 
$smtp-$met fd smtp; 
$title=$fdtitle."-- 反 馈 邮件 "; 
$query = "SELECT * FROM $met fdparameter order by no order"; 
$result = $db-»query ($query); 
while($1ist= $db->fetch array ($result) ){ 
$emaillist[]=$list; 
H 
for($k-0;$k«20; $k++) ( 
if($emaillist[$k] [use ok]--1)( 
$parafd-"para".$emaillist[$k] [id]; 
if ($en--"en")( 
$body-$body."«b»".Semaillist[$k][e name]."«/b»:".$$parafd."«br»"; 
) 
else( 
$body-$body."«b»".Semaillist[S$k] [c name]."«/b»:".$$parafd."«br»"; 
} 
} 
} 
$body=$body."<b> 反 馈 产 品 </b>: ".$fqtitle."<br>"; 
$body=$body."<b> 来 源 IP</b>: ".$ip."<br>"; 
$body=$body."<b> 提 交 时 间 </b>: ".$addtime. "<br>"; 
$body=$body ."<b> 来 源 页 面 </b>: ".$fromurl; 
jmailsend ($from, $fromname, $to, $title, $body, $usename, $usepassword, $smtp) ; 
) 
// 处 理 数据 库 信息 
if($met fd back--1)( 
$fdemail- $db-»get one("SELECT * FROM $met fdparameter WHERE 
c name-'$met fd email'"); 
$fdto-"para".$fdemail[id]; 
$fdto=$$fdto; 
jmailsend ($from, $fromname, $fdto, $met fd title, $met fd content, $usename, $ 
usepassword, $smtp) ; 
} 
if ($met fd type!=0){ 
$query = "INSERT INTO $met feedback SET 


fdtitle - '$title', 
fromurl = '$fromurl', 
ip = '$ip', 
addtime '$addtime', 
en = '$en', 
paral = '$paral', 
para2 = '$para2', 
para3 = '$para3', 
para4 = '$para4', 
para5 = '$para5', 
para6 = '$para6', 
para? = "paral sy 
para8 = '$para8', 
para9 = '$para9', 
paralO '$paral0', 
parall = sparalls 
paral2 = '$paral2', 
paral3 '$paral3', 
paral4 = '$paral4', 
paral5 = '$paral5', 
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paral6 = '$paral6', 
paral?7 = '$paral?7', 
paral8 = '$paral8', 
paral9 = '$paral9', 
para20 = '$para20'"; 


$db-»query ($query); 
) 
if ($en--"en")( 
okinfo('index.php?en-en',"Successfully, Thanks!"); 
Jelset 
okinfo('index.php', "反馈 信息 已 成 功 提交 ， 谢 谢 ! ") ; 
} 
H 
else( 
$query = "SELECT * FROM $met fdlist order by no order"; 
$result = $db-»query ($query); 
while ($list= $db->fetch array($result))( 
$fdlist[]-$1ist; 
} 


$query = "SELECT * FROM $met fdparameter where use ok='1' order by no order"; 
$result = $db->query ($query); 

while ($list= $db->fetch array ($result) ){ 

if ($list[wr_ok]=='1')$list[wr_must]="*"; 


6.4.4 ”基本 模块 


在 系统 框架 的 设计 里 ， 有 许多 功能 都 是 属性 信息 ， 如 分 页 信息 、 数 据 库 处 理 信息 、 邮 
件 发 送信 息 等 基本 模块 ， 这 些 模 块 都 不 在 系统 里 ， 但 是 系统 与 它 息息相关 ， 下 面 对 它 进行 
讲解 。 


1. 数据 库 配 置信 息 


在 设计 数据 库 时 ， 同 事 B 设计 了 数据 库 接口 ， 但 是 这 个 系统 每 一 个 模块 相同 的 操作 仍 
然 很 多 ， 所 以 需要 加 强 同事 B 编写 的 数据 库 信 息 ， 下 面 通过 一 段 代 码 进 行 讲 解 ， 其 代码 
(common .inc php) 如 下 : 


«?php 

header("Content-type: text/html;charset-utf-8"); 
error reporting(E ERROR | E PARSE); 

Gset time limit(0); 

// 获 取 程序 所 在 目录 

define('ROOTPATH', substr(dirname( FILE ), 0, -7)); 


PHP VERSION »- '5.1' && date default timezone set('Asia/Shanghai'); 
session cache limiter('private, must-revalidate'); 
Qini set('session.auto start',0); // 自 动 启动 关闭 
if(PHP VERSION « '4.1.0') ( 
GET-&SHTTP GET VARS; 
POST-&SHTTP POST VARS; 
COOKIE-&SHTTP COOKIE VARS; 
SERVER=&SHTTP SERVER VARS; 
ENV-&SHTTP ENV VARS; 
| FILES-&$HTTP POST FILES; 


4n 40 4n 40 40 4 
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require once dirname( file ).'/global.func.php'; 
define('MAGIC QUOTES GPC', get magic quotes gpc()); 
isset($ REQUEST['GLOBALS']) && exit('Access Error'); 


$settings - parse ini file(ROOTPATH.'config/config.inc.php'); 
Gextract ($settings); 


foreach(array(' COOKIE', ' POST', ' GET') as $ request) ( 

foreach($$ request as $ key => $ value) ( 

$ key(0) != ' ' && $$ key = daddslashes($ value); 

} 
} 
(!MAGIC QUOTES GPC) && $ FILES = daddslashes($ FILES); 
SREQUEST URI - $ SERVER['PHP SELF'].'?'.$ SERVER['QUERY STRING']; 
$t array = explode(' ',microtime()); 
SPST = $t array[0] + $t array[1]; 
$met obstart == 1 && function exists('ob gzhandler') E 
ob start('ob gzhandler') :ob start(); 
$referer?$forward-$referer:$forward-$ SERVER['HTTP REFERER']; 
$char key-array("NW",'&',' 
y mim aimi 40 M xr a a > HA pH NEP "n", tE, tet 120); 


$m now time = time(); 

$m now date = date('Y-m-d H:i:s',$m now time); 
$m now counter - date('Ymd',$m now time); 

$m now month = date('Ym',$m now time); 

$m user agent = $ SERVER['HTTP USER AGENT']; 


if($ SERVER['HTTP X FORWARDED FOR'])( 
$m user ip = $ SERVER['HTTP X FORWARDED FOR']; 
) elseif($ SERVER['HTTP CLIENT IP'])( 
$m user ip = $ SERVER['HTTP CLIENT IP']; 
) else( 
$m user ip - $ SERVER['REMOTE ADDR']; 
) 
$m user ip = preg match('/^([0-9](1,3)N.) (3) [0-9] (1,3) $/', $m user ip) ? 
$m user ip : 'Unknown'; 
$PHP SELF = $ SERVER['PHP SELF'] ? $ SERVER['PHP SELF'] = 
$ SERVER['SCRIPT NAME']; 
//$m mall skin dir = ROOTPATH. "templates"; 


$db settings = parse ini file(ROOTPATH.'config/config db.php'); 
Gextract($db settings); 


require once ROOTPATH.'config/tablepre.php'; 


// 语言 选择 

if (Sen--"en")( 

Ginclude once ROOTPATH.'language/language en.php'; 

H 

else( 

Ginclude once ROOTPATH.'language/language china.php'; 


} 

// MYSQL 数据 库 连接 

require once ROOTPATH.'include/mysql class.php'; 

$db = new dbmysql(); 
$db-»dbconn($con db host,$con db id,$con db pass,$con db name); 


// 显 示 参 数 转换 


$met e seo-stripslashes($met e seo); 
$met c seo-stripslashes($met c seo); 
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$met c foottext=stripslashes ($met c foottext); 
$met e foottext=stripslashes ($met e foottext); 
$met c footright=stripslashes ($met c footright); 
$met c footother=stripslashes (Smet c footother); 
$met e footright=stripslashes ($met e footright); 


$met e footother-stripslashes($met e footother); 
$met c webname-$met c webname."-- 开 发 笔记 技术 支持 "7 


2. 电子 邮件 


在 系统 编程 中 ， 需 要 电子 邮件 ， 它 也 是 重要 的 一 个 模块 ， 下 面 通 过 一 段 代 码 进行 讲解 ， 
其 代码 (email.class.php) 如 下 : 


«? 

/* 

* 邮件 发 送 类 

E 

class smail ( 

// 您 的 SMTP 服务 器 供应 商 ， 可 以 是 域名 或 IP 地 址 

Var $smtp = ""; 

//SMTP 需要 身份 验证 设 值 为 1 不 需要 身份 验证 值 为 0， 现 在 大 多 数 的 SMTP 服务 商都 要 验证 ， 如 
不 清楚 请 与 你 的 smtp 服务 商 联系 

var $check = 1; 

// 您 的 email 账号 名 称 

var $username = ""; 

// 您 的 email 密码 

var $password = ""; 
// 此 email 必须 是 发 信服 务 器 上 的 email 


var $s from - ""; 


/* 

* 功能 : 发 信 初 始 化 设置 

* $from 你 的 发 信服 务 器 上 的 邮箱 

* $password 你 的 邮箱 密码 

* $smtp 您 的 SMTP 服务 器 供应 商 ， 可 以 是 域名 或 IP 地 址 

* $check SMTP 需要 身份 验证 设 值 为 1 不 需要 身份 验证 值 为 0， 现 在 大 多 数 的 SMTP 服务 商都 要 验证 
eui 

function smail ( $from, $password, $smtp, $check = 1) ( 

if( preg match("/^[^NdV- ][NwN-]*[^N- ]8[^NV-] [a-zZA-ZNdN-] £ [^N7] (N- [^N-1I 
a-zA-ZNdNV-] * [^NV-]) *N. [a-zA-2] (2,3) /", S$from ) ) ( 

$this-»username -$from; //substr( $from, 0, strpos( $from , "Q" ) ); 
$this-»password = $password; 

$this-»smtp = $smtp ? $smtp : $this-»smtp; 

$this-»check = $check; 

$this-»s from = $from; 

) 

} 


x 


功能 : 发 送 邮件 
$to 目标 邮箱 
$from 来 源 邮 箱 
$subject 邮件 标题 
$message 邮件 内 容 
/ 


function send ( $to, $from, $subject, $message ) { 


»ox o X M 


* 
* 
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// 连 接 服务 器 

$fp = fsockopen ( $this-»smtp, 25, $errno, $errstr, 60); 
if (!$fp ) return "连接 服务 器 失败 "- LINE ; 

set socket blocking ($fp, true ); 


$lastmessage-fgets ($fp,512); 
if ( substr($1astmessage,0,3) != 220 ) 
return "错误 信息 1:$lastmessage". LINE ; 


//HELO 

$yourname = "YOURNAME"; 

if($this->check "1") $lastact="EHLO ".$yourname."\r\n"; 
else $lastact="HELO ".$yourname."NrWn"; 


fputs ($fp, $lastact); 

$lastmessage == fgets($fp,512); 

if (substr ($lastmessage, 0,3) != 220 ) 
return "错误 信息 2:$lastmessage". LINE ; 
while (true) { 

$lastmessage = fgets ($fp,512); 


if ( (substr ($lastmessage,3,1) != "-") or (empty ($lastmessage)) ) 
break; 

} 

// 身 份 验 证 

if ($this-»check--"1") { 

// 验 证 开始 


$1astact-"AUTH LOGIN"."Vr in"; 
fputs( $fp, $1astact); 
$1lastmessage = fgets ($fp,512); 


if (substr($1astmessage,0,3) !- 334) 
return "错误 信息 3:$lastmessage". LINE ; 
// 用 户 姓名 


$lastact-base64 encode ($this->username) ."\r\n"; 
fputs( $fp, $lastact); 
$lastmessage = fgets ($fp,512); 


if (substr($1astmessage,0,3) != 334) 
return "错误 信息 4:$lastmessage". LINE ; 
// 用 户 密码 


$1astact-base64 encode ($this->password) ."NrWMn"; 
fputs( $fp, $1astact); 

$1astmessage = fgets ($fp,512); 

if (substr($1astmessage,0,3) != "235") 

return "错误 信息 5:$lastmessage". LINE ; 

} 

/ /FROM: 

$lastact="MAIL FROM: <". $this->s from . ">\r\n"; 
fputs( $fp, $lastact); 

$lastmessage = fgets ($fp,512); 

if (substr($1astmessage,0,3) != 250) 

return "错误 信息 6:$lastmessage". LINE ; 

//TO: 

$lastact-"RCPI TO: <T. $to 1> NENDE; 

fputs( $fp, $lastact); 

$lastmessage = fgets ($fp,512); 

if (substr ($lastmessage, 0,3) != 250) 

return "错误 信息 7: $1astmessage". LINE ; 


人 多 - 
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//DATA 

$1astact-"DATANrAn"; 

fputs($fp, S$lastact); 
$lastmessage = fgets ($fp,512); 
if (substr($1astmessage,0,3) != 354) 
return "错误 信息 8: $1astmessage". LINE ; 
/ / s Subject 3k 

$head-"Subject: $subject\r\n"; 
$message = S$head."VrWn".$message; 
// 处 理 From 头 

$head-"From: $from\r\n"; 
$message = $head. $message; 

// 处 理 To 头 

Shead="To: $to\r\n"; 

$message = $head. $message; 

// 加 上 结束 串 

$message .= "\r\n.\r\n"; 
// 发 送信 息 

fputs ($fp, $message); 
$lastact="QUIT\r\n"; 

fputs ($fp, $lastace); 

fclose ($fp); 

return 0; 

} 


} 

/* 发 送 示例 

$sm = new smail( "用 户 名 8163.com"，" 密 码 "，"smtp.163.com" ); 

$end = $sm-»send( "目标 邮箱 "， "来源 邮箱 "， "这 是 标题 "，" 这 是 邮件 内 容 "”) ; 
if( $end ) echo $end; 

else echo "发 送 成 功 ! "; 

* 

z 


3. 分 页 功能 


网 站 随 着 使 用 时 间 的 增加 ， 信 息 也 将 变 得 越 来 越 多 ， 为 了 网 页 的 美观 ， 分 页 排列 是 必 
不 可 少 的 ， 下 面 通过 一 段 代码 进行 讲解 ， 其 代码 (pager.class.php) 如 下 : 


«?php 
class Pager( 
var $ total; // 记 录 总 数 
var $pagesize; // 每 一 页 显示 的 记录 数 
var $pages; // 总 页 数 
var $ cur page; // 当 前 页 码 
var $offset; // 记 录 偏 移 量 
var $pernum = 10; // 页 码 偏 移 量 ， 这 里 可 随意 更 改 


function Pager($total,$pagesize,$ cur page)( 
$this-» total-$total; 
$this-»pagesize-$pagesize; 
$this-» offset(); 
$this-» pager(); 
$this-»cur page($ cur page); 
f 
function _pager () // 计 算 总 页 数 { 
return $this->pages = ceil($this-» total/S$this-»pagesize); 
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function cur page($ cur page) // 设 置 页 数 { 
if (isset($ cur page)&&$ cur page!-0)( 
$this-» cur page-intval($ cur page); 
} 
else( 
$this-» cur page-1; // 设 置 为 第 一 页 } 
return $this-» cur page;] 
// 数 据 库 记 录 偏 移 量 
function offset(){ 
return $this-»offset-$this-»pagesize*($this-» cur page-1);) 
/ /ntml 数字 连接 的 标签 
function num link($tex-'?',S$url-'')( 
$setpage = $this-» cur page ? ceil($this-» cur page/S$this-»pernum) 
1; 
$pagenum = ($this-»pages > $this-»pernum) ? $this-»pernum : 
Sthis-»pages; 
if ($this-» total <= $this-»pagesize) ( 
$text - ''; 
) else ( 
$text = '«span class-list total»'.$this-» cur page.'/'.$this- 
»pages.'&nbsp;«/span»'; 
if ($setpage > 1) ( 
$lastsetid = ($setpage-1)*$this-»pernum; 
$text .= '«a class-webdings 
href-'.$tex.'pager-'.$1lastsetid.$url.'» 8 
«/a»'; } 
if ($this-> cur page > 1) ( 
$pre = $this-» cur page-1; 
$text .= '«a class-webdings 
href-'.$tex.'pager-'.$pre.$url.'»3«/a»';] 
$i = (S$setpage-1)*$this-»pernum; 
for($j-$i; $j«($i-$pagenum) && $j«$this-»pages; $j++) ( 
$newpage = $j+1; 
if ($this-> cur page == $j+1) { 


$text .= '<span>'.($j+1).'</span>'; 
) else ( 
$text .= '«a href- 


'.$tex.'pager-'.$newpage.$url.'»'.($j41).'«/a»'; 
b ub 
if ($this-» cur page < $this-»pages)(í 
$next = $this-» cur page+17 
$text .= '«a class= 
webdings href-'.$tex.'pager-'.$next.$url.'»4«/a»'; } 
if ($setpage < $this-> total) ( 
$nextpre = $setpage* ($this-»pernum*l); 
if ($nextpre«$this-»pages) 
$text .- '«a class- 
webdings href-'.$tex.'pager-'.$nextpre.$url.'»7«/a»'; 
FF 
return $text; 


l 
/ /html 连接 的 标签 
function link($url, $exc-'') 
t 

global $lang; 

$text-"«form method-'POST' name-'pagel' action-'".$url."' 
target-' self'»"; 

$text.- "Slang[pag total]«span»$this-»pages«c/span»$lang [pags] 
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< 


$lang[pag loction] 
<span>$this-> cur page</span>$lang[pags] "7 
if ($this-> cur page == 1 && $this->pages>1) ( 
// 第 一 页 
$text.= "$lang[pag home] $1ang[pag return] 
«a href-".$url.($this-» cur page 
*1).$exc."»$1ang[pag next]«/a» 
«a href-".$url.$this-»pages.$exc."»$1ang[pag end]«/a»"; 
} 
elseif ($this-> cur page == $this->pages && $this->pages>1) ( 
// 最 后 一 页 
$text.= "<a href-".$url.'l'.$exc."»$1lang[pag home]</a> 
«a href-".$url.($this- 
> cur page-1).$exc."»$1ang[pag return]«/a» 
$lang[pag next] $1ang[pag end]"; 
} 
elseif ($this-> cur page > 1 && $this-» cur page «- $this->pages) 
{ // 中 间 
$text.= "<a href-".$url.'l'.$exc."»$1lang[pag home]«/a» 
«a href-".$url.($this- 
> cur page-1).$exc."»$1lang[pag return]«/a» 
«a href-".$url.($this-» cur page-*1).$exc."» 


$lang[pag next]«/a» 
«a href-".$url.$this-»pages.$exc."»$1ang[pag end]«/a»"; 
} 
$text.=" $lang[pag go]«INPUT size-'1' name-'page input'»$lang[pags] "; 
$text.-"«input type-'submit' name-'Submit3' value-' GO ' class-'tj'» 
</form>"; 
return $text; 
} } 


4. 栏目 属性 设置 


不 管 是 什么 页 面 都 离 不 开 栏目 设置 ， 在 这 个 企业 网 站 信息 中 ， 设 置 与 其 他 网 站 有 所 区 
别 ， 下 面 通过 一 段 代码 进 行 讲解 ， 其 代码 (global.func.php) 如 下 : 


function daddslashes ($string, $force = 0) ( 
!defined('MAGIC QUOTES GPC') && define('MAGIC QUOTES GPC', 
get magic quotes gpc()); 
if(!MAGIC QUOTES GPC || $force) ( 
if (is array($string)) ( 
foreach($string as $key => $val) ( 
$string[$key] = daddslashes($val, $force); 
H 
) else ( 
$string = addslashes ($string); 
} 
} 
return $string; 
} 
function template ($template, $EXT="html1") { 
global $met_skin_user, $skin; 
if (empty ($skin) ) { 
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$skin = $met skin user; 

} 

unset ($GLOBALS [con db id],$GLOBALS[con db pass],$GLOBALS[con db name 
EE 

$path = ROOTPATH."templates/$skin/$template.$EXT"; 

!file exists($path) && $path=ROOTPATH."templates/met/$template.$EXT"; 

return $path; 
} 


/** 底 部 处 理 **/ 
function footer()( 
$output = 
Sstrereplace(array( eon ol c o MERCI Lok LL ECKE Eck 
','',"Nr",substr(S$admin url1,0,-1)),'',ob get contents ()); 
ob end clean(); 
echo $output; unset ($output); 
mysql close(); 
exit; 


5 

/** 操 作成 功 提示 **/ 

function okinfo ($url = '../site/sysadmin.php',$1anginfo)( 
echo ("<script type='text/javascript'> alert ('$langinfo'); 
location.href='$url'; </script>"); 

exit; 


} 

/** 是 否 导航 条 显示 **/ 

function navdisplay ($nav)( 

Switch ($nav)( 

case '0'; 

$nav-"«font color-4$999999»4 V «/font»"; 
break; 

case '1'; 

$nav-"«font color=#990000> 头 部 主导 航 条 </font>"7 
break; 

case '2'; 

$nav=" 尾 部 导航 条 "; 

break; 

case '3'; 

$nav-"«font color=blue> 都 显示 </font>"; 
break; 

} 

return $nav; 


5 

/xx 栏目 属性 显示 **/ 
function if in(Sif in)( 
switch ($if in)( 


case '0'; 
$if in=" 系 统 模块 "7 
break; 


case '1'; 

$if in-"«font color=red> 外 部 栏目 </font>"; 
break; 

} 

return $if in; 

} 

/** 模 型 显示 **/ 

function module ($module){ 

switch ($module)( 
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case '0'; 
$module-"«font color=red> 外 部 模块 </font>"; 
break; 

case '1'; 
$module-" (ij fr Bit" ; 
break; 

case '2'; 
$module=" 文 章 模块 "; 
break; 

case '3'; 
$module=" 产 品 模块 "; 
break; 

case '4'; 
$module-" 下 载 模块 "7 
break; 

case '5'; 
$module=" 图 片 模块 "; 
break; 

case '6'; 
$module=" 招 聘 模块 "; 
break; 

case '7'; 
$module=" 留 言 模块 "; 
break; 

) 

return $module; 


} 
// 删除 文件 的 函数 
function file unlink($file name) ( 
if (file exists ($file name)) ( 
@chmod ($file name, 0777); 
$area lord = Q@unlink ($file name); 
} 
return $area lord; 


} 

// 葛 态 页 面 生成 

function createhtm($fromurl,$filename)( 

$fp = fopen ($fromurl,"r"); 

$content = fread ($fp,filesize ($fromurl)); 

$handle = fopen ($filename,"w"); // 打 开 文 件 指针 ， 创 建文 件 
/* 

检查 文件 是 否 被 创建 且 可 写 

ey 


if (!is writable (S$filename))( 

okinfo('javascript:history.go(-1)',"X4[: " 

.$filename." 不 可 写 ， 请 检查 其 属性 后 重 试 ! "); 

5 

if (!fwrite (S$handle,$content))|  // 将 信息 写 入 文件 
die ("生成 文件 ".$filename." 失 败 ! ") 

} 

fclose ($handle); // 关 闭 指针 

die ("创建 文件 " .$filename." 成 功 ! "); 


// 热门 标签 函数 

function contentshow(Scontent) ( 

require once ROOTPATH.'config/str.inc.php'; 
foreach($str as Skey-»$val)( 


——— P Ó——————————————————— ——" » 


sA [ 
V 深入 体验 PHP 项 目 开发 和 


$content = str replace ($val[0],$val[1],S$content); 
} 

return $content; 

} 

// 读 取 数据 排序 

function list order($1listid)( 

switch ($listid)( 

case '0'; 

$list order=" order by updatetime desc"; 
return $list order; 

break; 

case '1'; 

$1ist order-" order by updatetime desc"; 
return $list order; 

break; 

case '2'; 

$list order=" order by addtime desc"; 
return $list order; 

break; 

case '3'; 

$list order=" order by hits desc"; 
return $list order; 

break; 

case '4'; 

$list order=" order by id desc"; 

return $list order; 

break; 

case '5'; 

$list order=" order by id"; 

return $list order; 

break; 

) 

) 

function 

jmailsend ($from, $fromname, $to, $title, $body, $usename, $usepassword, $smtp) 
{ 

$jmail-new COM("JMail.Message")or die ("无 法 调用 Jmail 组 件 "); 
// 屏 蔽 例外 错误 ， 静 默 处 理 
$jmail->silent=true; 

// 编 码 必须 设置 ， 否 则 中 文 会 乱码 
$jmail-»charset-"utf8"; 

// 发 信人 邮件 地 址 和 名 称 ， 能 自 定 义 ， 可 以 和 邮件 发 送 账号 不 同 
$jmail-»From-$from; 
$jmail-»FromName-$fromname; 

// 添 加 多 个 邮件 接受 者 
$toarray-explode("|",$to); 
S$tocount-count ($toarray); 

for ($k=0; $k<$tocount; $k++) { 
$jmail-»AddRecipient ($toarray[$k]); 


} 
// 邮 件 主题 和 正文 信息 
$jmail-»ContentType -'text/html'; 
// 设 置 邮件 格式 为 html 格式 
$jmail-»Subject = mb convert encoding ($title, 'GB2312', 'UTF-8'); 
$jmail-»Body = mb convert encoding ($body, 'GB2312', 'UTF-8'); 
// 发 信 邮 件 账号 和 密码 
$jmail-»MailServerUserName-$usename; 
$jmail-»MailServerPassword-$usepassword; 
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try{ 
$email = $jmail->Send ($smtp); 
if(Semail)$msg- ' 发 送 成 功 '; 
else $msg- ' 发 送 失 败 '; 
} catch (Exception $e)( 
$msg-$e-»getMessage(); 
) 
) 
function utf8Substr($str, $from, $len) 
t 
return 
preg_replace ('4£^(?:[Nx00-Nx7F] | [NXXCO-NxFF] [\x80-\xBF]+) (0, ' .$from.']'. 
* ((2: [NX00-Nx7F] | [NXXCO-NXFF] [NX80-NxBF] 4) (0, ' .$1en.']) .*£s', 
'$S1',$str); 


至 此 ， 企 业 门户 网 站 的 前 台 和 框架 设计 已 经 完成 ， 当 然 前 台 功 能 是 由 同事 C 负责 完成 
的 。 其 实 前 台 和 框架 是 紧密 相关 的 ， 所 以 在 此 阶段 我 俩 相互 交流 ， 很 好 地 完成 了 工作 。 我 
发 现 此 阶段 对 程序 代码 的 需求 不 是 很 高 ， 也 很 普通 ， 只 需要 用 户 对 前 台 设 计 的 观赏 性 下 工 
夫 。 不 管 是 哪个 企业 门户 网 站 ， 功 能 如 果 简 单 ， 观 赏 性 就 要 强 ， 对 于 网 站 制作 人 员 来 说 ， 
心思 应 花 在 明 面 的 页 面 设计 上 。 


在 本 系统 中 ， 前 台 尽 情 地 向 浏览 者 展示 数据 ， 后 台 则 是 面向 管理 者 。 若 想 管理 好 这 个 
网 站 ， 前 台 的 任何 信息 ， 都 需要 在 后 台 进 行 管理 。 前 台 的 工作 已 经 完成 ， 整 体 框架 也 已 经 
完成 ,今天 经 过 我 和 同事 C 沟通 之 后 ， 决 定 将 后 台 管理 进一步 完善 ， 让 它 管理 好 整个 网 站 。 


6.5.1 后 台 登 录 页 


后 台 登 录 页 是 管理 人 员 赁 着 用 户 名 和 密码 登录 后 台 的 窗口 ， 对 登录 账户 的 管理 十 分 如 
要 ， 下 面 通过 一 段 代码 进行 讲解 ， 其 代码 (login_check.php) 如 下 : 


«?php 
if ($admin index)( 
require once 'include/common.inc.php';// 调 入 数据 配置 文件 


Id 


} 

elseif (Sfckeditor)( 

require once '../../../../../include/common.inc.php';// 调 入 文件 
} 

else( 


require once '../include/common.inc.php';//iB A XffF 
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} 

if ($force index!="metinfo"){ 

if (!strstr($ SERVER['HTTP REFERER'],$ SERVER ['HTTP HOST']))( 
die ($1ang[nomeet]); 

H 

} 


if($action--"login")( 
$metinfo admin name $login name; 
$metinfo admin pass = $login pass; 
$metinfo admin pass-md5($metinfo admin pass); 
$met login code-1; 
// 登 录 验 证 码 判 断 
if ($met login code--1)( 
require once '../include/captcha.class.php'; 
$Captcha- new Captcha(); 
if(!$Captcha-»CheckCode ($code) ) { 
echo ("<script type-'text/javascript'» 
alert ('$lang[login code]');location.href-'login.php';«/script»"); 
exit; 


} 
} 


$admincp list = $db->get one ("SELECT * FROM $met admin table WHERE 
admin id='$metinfo admin name'"); 
if (!$admincp list) { 
echo ("<script type='text/javascript'> 
alert ('$lang[login name]');location.href-'login.php';«/script»"); 
exit; 
} 
elseif ($admincp list['admin pass']!--$metinfo admin pass)( 
echo ("<script type-'text/javascript'» 
alert('$1ang[login pass]');location.href-'login.php';«/script»"); 
exit; 
} 
else( 
session start(); 
$ SESSION['metinfo admin name'] = $metinfo admin name; 
/ UH P 
$ SESSION['metinfo admin pass'] = $metinfo admin pass;// 获 取 密 码 
$ SESSION['metinfo admin id'] = $admincp list[id];// 获 取 ID 号 
$ SESSION['metinfo admin pop'] = $admincp list['admin type']; 
// 获 取 用 户 类 型 
$ SESSION['metinfo admin time'] = $m now time;// 获 取 用 户 管理 的 时 间 
$query="update $met admin table set 
admin modify date-'$m now date', 
admin login-admin login+l, 
admin modify ip-'$m user ip' 
WHERE admin id = '$metinfo admin name'"; 
$db-»query ($query) ; 
l 
Header("Location: ../"); 
} 
if(!$metinfo admin name||!$metinfo admin pass){ 
if ($admin index)( 
Header("Location: login/login.php"); 
} 
elset{ 
Header ("Location: ../login/login.php");// 调 入 登录 页 面 
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6.5.2 ”对 产品 的 管理 

产品 中 心 是 整个 系统 的 核心 之 一 ， 管 理 好 产品 十 分 重要 ， 产 品 管理 包括 删除 产品 、 修 
改 产品 、 添 加 产品 等 ， 下 面 对 这 些 功能 进行 详细 讲解 。 

1. 添加 产品 

添加 产品 是 管理 者 向 系统 里 添加 新 的 产品 ， 用 户 在 表单 里 填写 信息 后 ， 提 交 给 数据 库 ， 
如 图 6-7 所 示 。 
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图 6-7 添加 产品 


下 面 通过 一 段 代码 进行 讲解 ， 其 代码 (addphp) 如 下 : 


«?php 

require once '../login/login check.php';// 调 入 页 面 

include once("../../fckeditor/fckeditor.php");// 调 入 页 面 

$query = "SELECT * FROM $met parameter where type=5 order by no order"; 
$result = $db-»query ($query); 

while($1ist = $db->fetch array ($result)) {// 搜 索 数 组 

if ($list[use ok]--1)$1ist p[]-$1ist; 

) 


$class2 ok-FALSE; 
$query = "SELECT * FROM $met column where module-5 order by no order"; 
$result = $db-»query ($query); 
while($list = $db->fetch array ($result)) ( 
if ($list[id]==$class1) {$classl name=$list[c name];} 
if($list[bigclass]==$class1){ 
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$column list2[]-$1list; 
$class2 ok-TRUE; 
} 
if($list[bigclass] !=0) $column list[]-$1ist; 
$ 
$i=0; 
echo "<script language = 'JavaScript'>\n"; 
echo "var onecount;\n"; 
echo "subcat = new Array(); Mn"; 
foreach ($column list as $key-»$vallist)( 
echo "subcat[".$i."] = new 


Array('".$vallist[c name]."','".$vallist[bigclass]."','".$vallist[id]."');An"; 


$i=$i+1; 
) 
echo "onecount-".$i."; Vn"; 
echo "</script>"; 
$css url-"../templates/".$met skin."/css";//CSS 样式 
$img url-"../templates/".$met skin."/images";// 图 片 地 址 
include template('img add'); 
footer(); 
?> 


2. 修改 产品 


当 完 成 产品 添加 后 ， 输 入 的 信息 未 必 准 确 ， 可 能 需要 对 产品 进行 修改 或 者 编辑 ， 如 


图 6-8 所 示 。 
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6-8 修改 产品 
下 面 通过 一 段 代码 进行 讲解 ， 其 代码 (editor.php) 如 下 : 


«?php 

require once '../login/login check.php';// 调 入 页 面 

include once("../../fckeditor/fckeditor.php");// 调 入 页 面 

$img list=$db->get one("select * from $met img where id-'$id'"); 
// 获 取 一 条 信息 
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if(!$img list)( 

okinfo('index.php',$1ang[noid]); 

H 

$query - "SELECT * FROM $met parameter where type-5 order by no order"; 
// 参 数 

$result = $db-»query ($query); 

while($1ist = $db-»fetch array($result)) {// 遍 历数 组 

if($list[use ok]==1) $list p[]-$1ist; 

} 


$classl=$img list[classl]; 

if ($img list[new ok]==1) Snew ok="checked='checked"'";// 检 测 图 片 列表 
if($img list[com ok]--1)$com ok-"checked-'checked' 
$class2[$img list[class2]]-"selected-'selected'"; 
if ($img list[class3]!-0)( 

$query ="select * from $met column where bigclass=$img list[class2] order 
by no order"; 

$result = $db-»query ($query); 

while($class3 r= $db->fetch array ($result) ) { 

$class3 list[]=$class3 r; 

b 

b 

$class3[$img list[class3]]-"selected-'selected'"; 


$class2 ok-FALSE; 
$query - "SELECT * FROM $met column where module-5 order by no order"; 
$result = $db-»query ($query); 
while ($list = $db->fetch array ($result)) ( 
if ($list [id]==$class1) {$class1 name-$list[c name];} 
if ($list [bigclass]==$class1) { 
$column list2[]=$list; 
$class2 ok=TRUE; 
} 
if ($list [bigclass] !=0) $column list[]=$list; 
} 
$i=0; 
echo "<script language = 'JavaScript'>\n"; 
echo "var onecount;\n"; 
echo "subcat = new Array(); Mn"; 
foreach($column list as $key-»$vallist)( 
echo "subcat[".$i."] = new 
Array('".$vallist[c name]."','".$vallist[bigclass]. 
Led 
$i=$i+1; 
} 
echo "onecount=".$i.";\n"; 
echo "</script>";// 显 示 JS 末尾 标记 
$css url-"../templates/".$met skin."/css";// 显 示 模 板 CSS 样式 
$img url-"../templates/".$met skin."/images";// 显 示 图 片 
include template('img editor');// 调 入 模板 信息 
footer(); 
?» 


3. 删除 产品 
当 发 布 的 产品 停产 或 者 其 他 的 原因 下 线 后 ， 可 不 对 此 产品 进行 宣传 展览 ， 此 时 管理 人 


àd 


> 


V 
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员 可 以 删除 这 个 产品 ， 其 实现 代码 (delete php) 如 下 : 


«?php 

require once '../login/login check.php';// 调 入 页 面 

include once("../../fckeditor/fckeditor.php");// 调 入 页 面 

$img list=$db->get one("select * from $met img where id='$id'"); 
// 获 取 一 条 记录 

if(!$img list)( 

okinfo('index.php',$1ang[noid]); 

H 

$query = "SELECT * FROM $met parameter where type=5 order by no order"; 
$result = $db-»query ($query); 

while ($list = $db-»fetch array($result)) {// 遍 历数 组 

if($list[use ok]--1)$1ist p[]=$list; 

$ 


$classl=$img list[classl]; 
if ($img list[new ok]--1)$new ok-"checked-'checked' 
if ($img list[com ok]--1)$com ok-"checked-'checked' 
$class2[$img list[class2]]-"selected-'selected'"; 
if ($img list[class3]!-0)( 
$query ="select * from $met column where bigclass=$img list[class2] order 
by no order"; 
$result = $db->query ($query) ; 
while($class3 r= $db->fetch array ($result) ){ 
$class3 list[]=$class3 r; 
) 
) 
$class3[$img list[class3]]-"selected-'selected'"; 
$class2 ok-FALSE; 
$query - "SELECT * FROM $met column where module-5 order by no order"; 
$result = $db-»query ($query); 
while ($list = $db->fetch array ($result)) ( 
if($list[id]--$class1l)($classl name=$list[c name];} 
if($list[bigclass]==$class1){ 
$column list2[]=$list; 
$class2 ok=TRUE; 
} 
if($list[bigclass]!-0) $column list[]-$1ist; 
H 
$i-0; 
echo "<script language = 'JavaScript'» Wn"; 
echo "var onecount; Mn"; 
echo "subcat = new Array(); Mn"; 
foreach($column list as $key-»$vallist)( 
echo "subcat[".$i."] = new Array('".$vallist[c name]. 
"ioe Sval istIbigcrasas). 2t ovat iid]. Ns 
$i=$i+1; 


} 
echo "onecount=".$i.";\n"; 
echo "</script>"; 


$css url-"../templates/".$met skin."/css"; 
$img url-"../templates/".$met skin."/images"; 
include template('img editor'); 

footer(); 

?» 
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4. 生成 静态 页 面 


产品 发 布 后 ， 将 会 生成 一 个 页 面 供 浏 览 者 查看 阅读 。 为 了 加 快 访问 效率 ， 此 网 站 将 通 
过 静态 页 面 的 方式 提供 给 浏览 者 。 下 面 通过 一 段 代 码 进行 讲解 ， 完 成 如 何 将 产品 生成 静态 
页 面 ， 其 代码 (savephp) 如 下 : 


«?php 

require once '../login/login check.php';// 调 入 页 面 
if ($action=="add") { 

$query = "INSERT INTO $met img SET 


c title = '$c title',// 中 文 文件 

e title 三 '$e_title',// 英 文 文件 
C keywords = '$c keywords', //"t 3X tis] 
e keywords = '$e keywords',//J3 XX fitis] 
c description = "$c_description',// 中 文 描述 
e description = '$e description', // 英 文 描述 
c content = '$c content',// 中 文 内 容 
e content = '$e content',// 英 文 内 容 
classl = "$classl',// 分 类 1 
class2 = "$class2',// 分 类 2 
class3 = '$class3',//4)2& 3 
new ok = '$new ok', 
imgurl = '$imgurl',//HKd rfi: 
imgurls = "$imgurls',// 喜 欢 的 图 片 
com ok = '$com ok', 
hits = 'S$hits'，// 单 击 时 间 
addtime = "$addtime'，// 添 加 时 间 
updatetime = '$updatetime', //W grin] 
c paral = '$c paral'，// 中 文 
c para2 = '$c para2', 
c para3 = '$c para3', 
c para4 = '$c para4', 
c para5 = '$c para5', 
c para6 = '$c parab"; 
c para7 = '$c paral", 
c para8 = $c parag!, 
c para9 = '$c para9', 
c paralO = '$c paral0', 
e paral = Soparal', 
e para2 = '$e para2', 
e para3 = 798 paraa"; 
e para4 = '$e para4', 
e para5 = "$e pafas., 
e para6 = $e para’, 
e para7 = Se para7*; 
e para8 = '$e paras’, 
e para9 = "$e para9', 
e paral0 = "$e paral0'"; 

$db-»query ($query); 


// 更 态 页 面 生成 


$later img=$db->get one("select * from $met img where 
g=: g g 


updatetime='Supdatetime'");// 获 得 一 条 记录 


$id-$later img[id]; 


$folder-$db-»get one("select * from $met column where id-'$classl'"); 
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// 获 取 一 条 记录 

if($met webhtm==1) { 

$fromurl-$met weburl.$folder[foldername]."/showimg.php?id-".$id; 
$filename-"../../".$folder[foldername]."/"."showimg".$id.".htm"; 
createhtm($fromurl,$filename); 

if($met en lang--1)( 

$fromurl-$met weburl.$folder[foldername]."/showimg.php?e 
$filename-"../../".$folder[foldername]."/"."showimg".$id. 
createhtm($fromurl,$filename); 

$ 

} 

if($met index type) { 


=en&id=". $id; 
" en.htm"; 


if($met webhtm--1)( 
$fromurl-$met weburl."/index.php?en-en"; 
$filename-"../../index.htm"; 
createhtm($fromurl,$filename); 
if($met en lang--1)( 
$fromurl-$met weburl."/index.php?ch-ch"; 
$filename-"../../index ch.htm"; 
createhtm($fromurl,$filename); 
nr 
}else{ 
if($met webhtm==1) { 
$fromurl=$met weburl."/index.php"; 
$filename-"../../index.htm"; 
createhtm($fromurl,$filename); 
if($met en lang--1)( 
$fromurl-$met weburl."/index.php?en-en"; 
$filename-"../../index en.htm"; 
createhtm($fromurl,$filename); 
pu 
okinfo('index.php?classl-'.$classl,$1ang[user admin]);! 
if(S$action--"editor")( 
if($met en lang--1)( 
$query = "update $met img SET 
c title 
// 中 文 标题 
e title 
// 英 文 标题 
C keywords = '$c keywords', 
// 中 文 关键 字 
e keywords = '$e keywords', 
// 英 文 关键 字 
C description = '$c description', 
// 中 文 描述 
e description = '$e description', 
// 英 文 描述 
c content = '$c content', 
// 中 文 内 容 
e content = '$e content', / / 3E 3C 7E 
classl = "$class1l',// 类 型 1 
class2 = '$class2',// 类 型 2 
class3 = '$class3',// 类 型 3 
new ok = '$new ok', 
imgurl '$imgurl',// 图 片 地 址 
imgurls = '$imgurls', 
com ok = '$com ok', 


"$C title', 


"$e title', 
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hits 二 
addtime = '$addtime', 
updatetime = '$updatetime', 
C paral = '$c paral', 
c para2 — '$c para2', 
C para3 = "$c para3', 
c_para4 = '$c para4', 
c para5 = "$c parab5', 
c para6 = '$c para6', 
C para? = '$c para7', 
c para8 = '$c para8', 
C para9 = "$c para9', 
c paral0 '$c paralO', 
e paral = "$e paral', 
e para2 = "$e para2', 
e para3 = '$e para3', 
e para4 = '$e para4', 
e para5 '$e para5', 
e para6 '$e para6', 
e para? "Se para?', 
e para8 '$e para8', 
e para9 = '$e para9', 
e paral0 = '$e paral0' 
where id-'$id'"; 
}else{ 
$query = "update $met img SET 

c title = '$c title', 
C keywords = '$c keywords', 
C description = '$c description', 
c content = '$c content', 
classl = '$classl', 
class2 = '$class2', 
class3 = '$class3', 
new ok = '$new ok', 
imgurl = '$imgurl', 
imgurls = '$imgurls', 
com ok = '$com ok', 
hits = '$hits', 
addtime = '$addtime', 
updatetime 'Supdatetime', 
c paral = "$c paral', 
c para2 = "$c para2", 
c para3 = '$c para3', 
c para4 = '$c para4', 
c para5 = '$c para5', 
c para6 = Scopara6; 
c para? = tSc paral", 
c para8 = '$c paraB8', 
c para9 = '$c para9', 
c paralO = "$c paralO' 


where id='$id'";} 
$db->query ($query); 
// 葛 态 页 面 生成 


$folder=$db->get one("select * from $met column where id='$class1'"); 


// 获 取 一 条 记录 
if(Smet webhtm--1)( 


Sfromurl-$met weburl.$folder[foldername] 
$filename-"../../".$folder[foldername]."/"."showimg".$id.".htm"; 


createhtm($fromurl,$filename); 


showimg.php?id-".$id; 


bad 
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if($met en lang--1)( 

$fromurl-$met weburl.$folder[foldername]."/showimg.php?en-en&id-".$id; 
$filename-"../../".$folder[foldername]."/"."showimg".$id." en.htm"; 
createhtm($fromurl,$filename); 

lr 

if($met index type)t 

if($met webhtm--1)( 

$fromurl-$met weburl."/index.php?en-en"; 
$filename-"../../index.htm"; 
createhtm($fromurl,$filename); 

if($met en lang--1)( 

$fromurl-$met weburl."/index.php?ch-ch"; 
$filename-"../../index ch.htm"; 
createhtm($fromurl,$filename);]] 

}else{ 

if($met webhtm==1) { 

$fromurl=$met weburl."/index.php"; 
$filename-"../../index.htm"; 
createhtm($fromurl,$filename); 

if($met en lang--1) 

t 

$fromurl-$met weburl."/index.php?en-en"; 
$filename-"../../index en.htm"; 
createhtm($fromurl,$filename); 

) 

) 

J 

okinfo('index.php?classl-'.$classl,$1ang[user admin] ) ; } 
E 


方法 

至 此 ， 系 统 的 后 台 功 能 全 部 设计 完毕 ， 我 感慨 颇 多 ， 收 获 也 不 少 ， 我 发 现 后 台 各 个 栏 
目的 管理 都 大 同 小 异 ， 只 要 和 弄 清 一 个 栏目 的 管理 后 ， 其 他 栏目 的 问题 都 可 以 用 相同 的 方式 
得 到 解决 。 所 有 栏目 都 是 基于 对 数据 库 数据 的 添加 、 删 除 和 修改 操作 ， 只 是 处 理 的 数据 库 
表 不 同 而 已 。 总 结 已 经 结束 ， 我 压抑 了 “ 偷 菜 ”的 冲动 ， 决 定 为 明天 的 工作 养 精 蓄 锐 。 
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| 2008365299, v, 开始 测试 
经 过 过 去 一 段 时 间 的 忙碌 后 ， 整 个 项 目 终于 开发 完成 了 ， 最 后 的 项 目测 试 工作 由 我 来 
完成 。 在 此 我 将 工程 命名 为 “06news”。 


6.6.1 系统 运行 预览 


现在 开始 运行 测试 , 项 目 运行 后 的 主 界面 效果 如 图 6-9 所 示 , 在 主 界面 中 向 浏览 者 展示 
导航 栏 、 产 品 信息 和 公司 简介 以 及 最 新 动态 。 


人 = 
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图 6-9 系统 主 界面 


6.6.2 验收 
F389$68309,4 — 
在 规定 的 时 间 内 ， 我 们 的 项 目 正式 投放 运行 ， 合 作 方 使 用 后 普遍 反映 不 错 ， 这 很 好 地 


为 我 们 夺 得 了 头 彩 。 我 们 4 个 人 共同 考虑 系统 优化 等 方面 的 问题 ， 并 整理 了 份 报告 交 给 了 
客户 ， 如 果 有 什么 需要 ， 请 他 们 拨打 电话 联系 我 们 。 


6.6.3 总结 


在 炎热 的 夏 日 里 ， 我 们 的 项 目 终于 通过 了 客户 的 验收 。 这 个 企业 网 站 项 目 实际 上 就 是 
新 闻 发 布 系统 的 衍生 品 ， 在 当前 的 互联 网 时 代 里 ， 新 闻 发 布 系统 是 一 个 较为 简单 的 系统 。 
根据 对 这 个 项 目的 亲身 体验 ， 我 总 结 出 了 以 下 3 条 经 验 。 

1) 出 色 的 界面 引 人 关 注 

再 复杂 的 程序 ， 对 于 外 行人 来 说 ， 他 们 也 无 法 弄 懂 ， 但 是 界面 好 看 不 好 看 ， 他 们 有 权 
说 出 ， 对 于 审美 较 差 的 程序 员 来 说 ， 可 以 借鉴 一 下 同类 型 的 网 站 配色 方案 ， 如 是 科技 行业 ， 
看 看 其 他 科技 行业 的 网 站 的 配色 ， “山寨” 出 来 ， 让 你 的 网 站 从 美工 上 说 ， 不 落后 于 人 。 

2) 简单 易 用 永远 是 第 一 要 务 

对 于 企业 或 者 政府 单位 的 一 些 非 程序 员 出 身 的 人 来 说 ， 他 们 要 求 的 系统 是 简单 好 用 ， 
对 于 程序 员 来 说 ， 只 要 多 花 点 心思 ， 就 能 解决 这 些 问 题 。 关 于 简单 易 用 ， 在 做 系统 时 ， 多 
做 提示 或 者 向 导 性 的 东西 ， 就 会 立刻 让 使 用 者 感觉 到 这 个 系统 的 易 用 ， 并 录制 视频 ， 教 授 
他 们 每 一 个 功能 。 

3) 伪 静 态 页 面 处 理 的 必要 性 

新 闻 系 统 是 文章 发 布 系统 ， 信 息 终归 是 需要 搜索 引擎 来 搜索 ， 当 然 别 人 搜索 得 越 快 、 
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越 多 越 好 ， 可 是 对 于 数据 库 动态 系统 和 静态 系统 ， 搜 索 更 倾向 于 静态 系统 。 为 了 让 搜索 引 
擎 更 好 地 获取 新 闻 发 布 系统 的 内 容 ， 可 以 使 用 伪 静 态 页 面 ， 伪 静态 是 相对 真实 静态 来 讲 的 
通常 我 们 为 了 更 好 地 缓解 服务 器 的 压力 和 增强 搜索 引擎 的 友好 面 ， 都 将 文章 内 容 生 成 静态 
页 面 ， 但 是 有 的 朋友 为 了 实时 地 显示 一 些 信息 ， 或 者 还 想 运用 动态 脚本 解决 一 些 问题 不 能 
用 静态 的 方式 来 展示 网 站 内 容 ， 但 动态 页 面 损失 了 对 搜索 引擎 的 友好 面 ， 怎 么 样 在 两 者 之 
间 找 个 中 间 方 法 呢 ? 在 新 闻 发 布 系统 的 网 站 里 ， 建 议 使 用 伪 静 态 页 面 技术 ， 它 对 新 闻 发 布 
系统 十 分 重要 ， 但 是 容易 被 开发 人 员 忽 视 。 
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自 阿 里 巴巴 成 功 以 来 ,中 国 的 电子 商务 进入 了 一 个 新 
新 的 时 代 ， 随 便 上 网 浏览 ， 购 物 的 网 站 多 如 牛 毛 。 由 此 可 
见 ， 电 子 商务 利用 简单 、 快 捷 、 低 成 本 的 电子 通信 方式 ， 
买卖 双方 不 见面 而 完成 各 种 商业 活动 ， 逐 渐 被 人 们 接受 。 
电子 商务 是 一 种 新 新 的 商务 运作 模式 ， 受 到 越 来 越 多 的 企 
业 的 高 度 重视 。 

在 本 章 的 内 容 中 ,将 详细 讲解 电子 商务 网 站 系统 的 构 
建 ， 旨 在 让 读者 牢固 掌握 SQL 后 台数 据 库 的 建立 、 维 护 
以 及 前 台 应 用 程序 的 开发 ， 为 以 后 深入 地 学 习 打 下 坚实 的 
基础 。 


V 深入 体验 PHP 项 目 开 发 


四 < SO z 


7.1 新 项 目的 挑战 


当 我 还 在 念 大 一 的 时 候 ， 我 看 到 网 上 许多 诱 人 的 东西 ， 价 格 便宜 ， 想 购买 的 时 候 ， 却 
常 听 周边 的 同学 说 ， 网 上 没有 好 货 、 假 货 多 、 容 易 受 骗 。 我 还 是 购买 了 ， 后 来 发 现 ， 网 上 
购物 和 现实 中 一 样 ， 好 坏 都 有 ， 关 键 看 购买 者 怎么 区 别 ， 最 近 两 年 ， 电 子 商务 购物 平台 越 
来 越 多 ， 网 络 购物 成 了 一 种 新 的 购物 方式 。 


7.1.1 项 目 来 源 
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接 到 公司 总 经 理 一 个 电话 ， 说 是 公司 要 成 立 电 子 商务 网 站 平台 。 虽 然 电子 商务 平台 如 
此 之 多 ， 但 是 仍然 有 十 分 大 的 市 场 ， 这 个 电子 网 站 的 设计 工作 肯定 是 由 我 来 完成 。 我 得 到 
这 个 消息 后 ， 赶 紧 看 一 下 手 上 的 人 员 够 不 够 担当 这 个 项 目 ， 得 组 建 一 支 好 的 团队 才能 完成 。 


7.1.2 ”组建 团队 
| 3-95068189,95 — 


项 目 不 算 大 ， 公 司 能 让 我 用 的 人 也 不 多 ， 我 将 能 用 的 人 组 建 了 一 个 团队 ， 团 队 成 员 
如 下 。 

同事 A: 

他 来 自 云南 大 理 的 一 个 少数 民族 ， 会 许多 少数 民族 乐器 ， 有 许多 乐器 我 都 是 第 一 次 见 
到 ， 对 他 有 种 极为 佩服 的 感觉 ， 他 在 策划 方面 尤为 突出 ， 在 大 学 期 间 ， 因 为 设计 软件 屡屡 
获奖 。 

任务 : 负责 项 目 规划 ， 撰 写 系 统 设计 规划 书 。 

同事 B: 

他 来 自 万 州 ， 除 了 喜欢 计算 机 外 ， 还 喜欢 雕刻 ， 从 事 软 件 开发 已 经 半年 了 ， 对 需求 分 
析 和 数据 库 设计 比较 有 天 赋 。 

任务 : 负责 需求 分 析 和 数据 库 设计 。 

同事 C: 

此 人 给 我 的 印象 十 分 成 熟 ， 不 喜欢 太 剧 烈 的 运动 ， 对 羽毛 球 十 分 热爱 ， 不 管 酷暑 还 是 
严 案 ， 都 坚持 锻炼 。 

任务 : 负责 商城 管理 系统 购物 车 、 买 卖 等 模块 。 

我 : 
目前 是 公司 项 目 组 组 长 ， 是 芽 界 一 只 待 飞 的 小 鸟 。 
任务 : 负责 系统 整体 框架 设计 ， 并 协调 项 目 中 各 个 模块 的 进展 。 
具体 职能 结构 如 图 7-1 所 示 。 
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同事 B 
需求 分 析 和 数据 


库 设计 


同事 C 
负责 商城 管理 系 
igo. x 


我 
等 模块 整体 框架 


协调 


图 7-1 职能 结构 图 


整个 项 目的 具体 操作 流程 是 : 项 目 规划 一 数据 库 设计 一 框架 设计 一 商城 购物 车 、 用 户 
管理 、 图 书 借阅 。 


7.1.3 小 会 议 
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今天 我 将 项 目 组 成 员 组 织 在 一 起 开 了 一 个 简单 的 项 目 会 议 ， 会 上 实现 了 一 个 简单 的 规 
划 。 一 致 认为 本 项 目 包括 后 台数 据 库 的 建立 、 维 护 以 及 前 端 应 用 程序 的 开发 3 个 方面 。 在 
制作 的 过 程 中 ， 要 用 较 少 的 代码 ， 完 成 更 多 的 功能 ， 要 重复 利用 一 些 代 码 ， 从 而 减低 开 
发 难度 。 

大 家 一 致 提议 同事 A 尽快 作出 规划 书 ， 后 续 工 作 将 以 规划 书 为 基础 进行 扩展 。 


7.2 系统 概述 和 总 体 设计 
(20965209, Eod 


今天 阳光 明媚 ， 一 向 做 事 讲究 效率 的 同事 A 做 好 了 项 目 规划 书 ， 整 个 规划 书 分 为 以 下 
两 个 部 分 。 

ü 系统 需求 分 析 

O ”系统 运行 流程 


7.2.1 系统 需求 分 析 
所 谓 电子 商务 平台 ， 实 际 上 就 是 在 网 络 上 建立 一 个 虚拟 的 超市 ， 其 具体 功能 如 下 。 
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1. 商品 信息 展示 

这 一 模块 将 完成 所 有 的 商品 展示 ， 让 浏览 者 更 好 地 选择 商品 ， 更 好 地 购物 。 

2. 用 户 管理 

这 是 一 个 典型 的 购物 商城 ， 有 许多 的 用 户 ， 管 理 人 员 需 要 对 这 些 用 户 进行 管理 ， 如 购 
物 数量 、 购 物 时 间 等 信息 。 

3. 购物 车 

购物 车 相当 于 超市 购买 商品 ， 将 要 购买 的 商品 放 在 篮子 里 ， 购 买 完毕 后 去 结账 。 

4. 订单 

订单 是 商城 购物 比较 重要 的 环节 ， 在 这 个 栏目 里 有 查看 订单 、 执 行 订单 、 删 除 订单 和 


打印 订单 等 功能 模块 。 
根据 需求 分 析 中 总 结 的 用 户 需求 来 设计 系统 的 体系 结构 ， 每 一 个 功能 模块 都 需要 针对 
不 同 的 表 完 成 相同 的 数据 库 操作 ， 即 添加 记录 、 删 除 记 录 、 查 询 记录 、 更 新 记录 。 


7.2.2 ”系统 运行 流程 


在 此 模拟 了 系统 的 运行 情景 : 运行 系统 后 ， 首 先 会 进入 首页 ， 如 果 是 首次 登录 的 用 户 ， 
需要 注册 ， 如 果 是 老 用 户 ， 需 要 登录 系统 ， 如 图 7-2 所 示 。 
p C | ed 
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没 想到 在 完成 会 议 之 后 ， 仅 仅 用 了 一 天 的 时 间 ， 同 事 A 的 系统 规划 工作 就 大 功 告 成 。 
有 了 这 个 规划 书 ， 我 们 以 后 的 工作 就 有 目的 性 了 ， 以 后 的 工作 可 以 根据 这 个 规划 书 进行 扩 
充 即 可 。 接 下 来 ， 需 要 同事 B 来 完成 数据 库 设计 工作 。 
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7.3 数据 库 设计 


HR, HEKA 


今天 同事 B 开始 搭建 系统 数据 库 。 开 发 数据 库 管 理 信息 系统 需要 选择 后 台数 据 库 和 相 
应 的 数据 库 访 问 接口 。 后 台数 据 库 的 选择 需要 考虑 用 户 需求 、 系 统 功 能 和 性 能 要 求 等 因素 。 
考虑 到 系统 所 要 管理 的 数据 量 比较 大 ， 且 需要 多 用 户 同时 运行 访问 ， 本 项 目 将 使 用 和 PHP 
结合 最 好 的 MySQL 作为 后 台数 据 库 管理 平台 。 


7.3.1 数据 库 结构 的 设计 


由 需求 分 析 的 规划 可 知 整个 项 目 对 象 有 16 种 信息 ， 从 而 系统 也 需要 包含 16 个 数据 库 
表 。 为 节省 本 书 篇 幅 ， 在 下 面 将 对 其 中 重要 的 6 个 数据 库 信 息 表 进 行 讲解 。 
(1). 商品 分 类 信息 表 (hono_cart_category)， 用 来 保存 商品 分 类 信息 ， 表 结构 如 表 7-1 


所 示 。 
表 7-1 商品 分 类 信息 表 
字段 类 型 整理 属性 nu RA 额外 
id int(11) auto increment 
pid int(11) 
nodepath varchar(255) utf8 general ci 


name varchar(100) utf8 general ci 
url varchar(255) utf8 general ci 
picture varchar(66) — utf8 general ci 
sortid 


" RERERRE F 


(2) 收藏 信息 表 (hono_cart_favorites)， 用 来 保存 用 户 喜 欢 的 商品 信息 ， 表 结构 如 表 7-2 


所 示 。 
表 7-2 收藏 信息 表 
字段 类 型 整理 属性 Null RU LL 
id int(11) Ej auto increment 
username  varchar(85) utf8 general ci 是 NULL 
product id int(11) 是 NULL 


(3) 商城 菜单 信息 表 (hono_cart_ mainmenu), 用 来 保存 商城 购物 菜单 , 表 结 构 如 表 7-3 所 示 。 
表 7-3 ”商城 菜单 信息 表 


字段 类 型 整理 属性 ”Null 默认 额外 
id int(11) Ed 
menu name varchar(100) utf8 general ci EJ 
description text utfS general ci EJ 
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(4) 商城 结构 目录 信息 表 (hono cart menu)， 用 来 保存 商城 结构 目录 ， 表 结构 如 表 7-4 


所 示 。 
表 7-4 商城 结构 目录 信息 表 
字段 类 型 整理 属性 ”Null RU LL 

id int(11) EJ auto increment 
name varcha(85)  utfe general ci 是 NULL 

uri varchar(255) utf8 general ci 是 NUL 

pid int(11) 是 nu 

picture varchar(50) —utf8 general ci Ej 

func id varchar(255) utf8 general ci E 

func name  varchar(255) utf8 general ci 否 

sortid int(11) 是 NULL 

is user —— tinyint(1) 是 NULL 


(5) 购物 车 信息 表 (hono_cart_ modules)， 用 来 保存 购物 车 信息 ， 表 结构 如 表 7-5 所 示 。 
表 7-5 购物 车 信息 表 


字段 类 型 整理 EH nun RA "s 

id int(11) 否 auto_increment 
pid int(11) 否 

nodepath varchar(255) utf8 general ci ES 

module name varchar(100) utf8 general ci Ej 

description text utf8 general ci 8 

module page  varchar(255) utf8 general ci Ej 

dispach page tinyint(1) EJ 

picture varchar(100) uff8 general ci Ej 

access level — tinyint(1) 否 1 

page level tinyint(2) 否 1 


(6) 商城 用 户 信息 表 (hono cart. users), 用 来 保存 商城 购物 者 的 信息 , 表 结 构 如 表 7-6 所 示 。 
表 7-6 商城 用 户 信息 表 


字段 类 型 整理 属性 Nul RU LL 
E] int(11) EJ auto increment 
UserGrade ints) * NULL 
site id varchar(50) — uff8 general ci 是 1 
username varchar(255) tfe general ci 是 nu 
psw varchar(255) utf8 general ci 是 nu 
EmailName varchar255) utf8 general ci z 
true name varchar(50) — utf8 general ci Ej 
telepnone varchar50) — utf8_general_ci 8 
moblie varchar(50) ute_general_ci Ej 
date of birth date 是 nu 
country varchar(50) — uff8 general ci 是 nuu 
province. state varchar(50) — uffé general ci 是 vu 
County varchar(50) — utf8 general ci 是 NULL 
zip code varchar20) — uff8 general ci 是 Nu 
sex tinyint(4) 是 NULL 
my_website varchar255) uff general ci 是 NULL 
my location. warchar255) utf8 general ci 是 NULL 
introducton text utf8 general ci 是 NULL 
college area varchar100) utf8 general ci Ej 
college. varchar100) uff general ci Ei 
upload type inyint(4) 是 nuu 
photo Varcharf255) uff8 general ci 是 nu 
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7.3.2 ”数据 库 连 接 信息 


当 建 立 好 数据 库 后 ， 数 据 库 设 计 人 员 需 要 建立 一 个 配置 文件 ， 供 程序 员 调用 数据 库 ， 
下 面 通过 一 段 程序 进行 讲解 ， 其 代码 如 下 : 


" 


«?phpphp 
/* 


/ 数据 库 配置 信息 


//db 
$mysglhost-"127.0.0.1"; // 服 务 器 地 址 
$mysqluser-"root"; // 用 户 名 
$mysqlpwd-"1234"; /[ 
$mysqldb-"07shop"; // 数 据 库 名 
i * 
S GNAEUS MM INANEM CI LI ILAEU RES MEE ERU 
/ 表 信息 
/ * 
Ro su a GINUDUESI MP IIO RGGERAGCI NUNG E EIE; QU DNO 


$TablePre = 'hono '; 

// 授 权 表 
$TableMenu-$TablePre."cart menu";// 表格 目录 
$TableAdmin=$TablePre."cart users";// 表 格 用 户 
$TableRole-$TablePre."cart role"; // 购 物 角 色 
$TableMenu role=$TablePre."cart menu role";// 购 物 目录 角色 
$TableUser=$TablePre."cart users";// 购 物 用 户 名 
$TableSite category=$TablePre."cart site";// 购 物 地 址 

// 系 统 配置 
$TableConfig =$TablePre."cart config";// 购 物 车 配置 
$TableTemplates-$TablePre."cart templates";// 购 物 车 模板 
$TableModules-$TablePre."cart _modules";// 购 物 模块 
$TableMain menu-$TablePre."cart mainmenu";// 购 物 车 菜单 

// 条 款 
$TableInfo category=$TablePre."cart menuitem";// 购 物 目录 条 款 
$TableInfos=$TablePre. "cart infos"; 

// 购 物 车 
$TableEb order product = $TablePre."cart order product";// 购 物 车 简历 
$TableEb product = $TablePre."cart product";// 购 物 车 产品 
$TableEb product category = $TablePre."cart category";// 购 物 车 种 类 
$TableEb product order = $TablePre."cart order";// 购 物 车 命令 
$TableEb remark = $TablePre."cart remark";// 购 物 注意 事项 


$TableEb product favorites- $TablePre."cart favorites";// 购 物 车 收藏 夹 
define(" ACCESS ","ok"); 
function getVirtualDirectory() 


v. [ 
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$returnvalue-""; 

$current dir-str replace ('\\','/',dirname( FILE )); 

S$DRoot-$ SERVER['DOCUMENT ROOT']; 

if(Scurrent dir--$DRoot) 

return $returnvalue; 

$current dir array-explode ($DRoot,$current dir); 

$returnvalue.-$current dir array[l]; 

return $returnvalue; 

y 
$TitleName = " 萌 女 郎 商 务 网 后 台 "; //«title»«/title». 
$pagenum = 15; 
$WebHost-$ SERVER['HTTP HOST']; 
SSETUPFOLDER-getVirtualDirectory(); 
$BASEPATH = dirname( FILE ); 
$UploadPath = S$BASEPATH."/"; // 上 传 文件 路 径 
$HostUrl = "http://".$WebHost."/";// 服 务 器 地 址 
$Site No= "1"; // 站 点 设置 
$dispatch page- "index.php"; 
$T Page Level =array(1=>" 首 页 " 
$T Module Position =array (1=>" 
页 面 ", "用 户 页 面 "); 

$T Bgcolor-array (1=>"#FBFDDB", " E3E3E3") ;// 设 置 背景 颜色 
$T Editor type-array (1-»"Text", "oFCKeditor", "eWebeditor");/ /编辑 类 型 
$T ToolbarSet-"Basic" 
$T FkDefaultLanguage-"zh-cn"; 
$T Fk sBasePath-S$SETUPFOLDER."/admin/fckeditor/"; 


二 级 页 面 ", "详细 页 面 ") ; 
v "首页 左边 ", "首页 中 间 ", "首页 右边 "," 子 


// 信 息 
$T Is YesNO- array (1=>" 是 "," 否 "); 
$T Gender =array(1=>" B", "4"; 
$T Avatar Type =array (1=>" 上 传 ", "IKA", "默认 ") ; 
$T Link method -array(1-»" top"," parent"," blank"); 
$T Upload Type =array (1=>" 图 片 ", "文件 ", "媒体 "); 
$T Dispach =array (1=>"Index", "Profile"); 
$T Dispach Page -array(1-»"index.php","profile.php"); 
$T Access Level =array (1=>" AF", MEM", "特权 ") ; 
$T Url type =array (1=>" 从 模块 选择 ", "输入 "); 
// 产 品 
$T Price type- array(1-»"$","Y"); 
$T Order status- array (1=>" 处 理 中 ", "取消 ", "完成 ") ; 
// 阻 止 不 必要 信息 
$Instail dir-$BASEPATH."/install"; 
if (file exists ($Instail dir)) 
{ 


header("location: ".$SETUPFOLDER."/install"); 
exit(); 


include S$BASEPATH."/include/function.php"v//iB A Jt il ; 
ini set("session.use cookies","1"); 
session start(); 
import request variables ("pg"); 
error reporting (7); 
error reporting(E ALL^(E NOTICE|E WARNING)); 
obstant: 
if ($ SERVER['QUERY STRING'] !- '' 
&& !preg match('/^(|[a-z&-0-9 ]*)$/is', chop($ SERVER['QUERY STRING']))) 
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exit ("Restricted access!"); 


?» 


7.8.3 数据库 编程 


在 整个 系统 中 ， 操 作 数据 库 的 方法 基本 相似 ， 用 户 可 以 编辑 一 些 类 似 的 代码 ， 供 程序 
员 调 用 就 可 以 了 ， 下 面 将 通过 一 段 代码 进行 讲解 ， 其 代码 如 下 : 


<?php include dirname( FILE )."/../Configuration.php"?>// 调 入 页 面 


<?phpphp 
class db driver {// 数 据 库 驱 动 
var $query id = "";//SEjS id 


var $connection id = "";//XERE ID 
var $query count = 0;// 统 计 


var $record row = array();// 档 案 行 业 
var $return die = 0; 
var $error eu 


var $record object = array(); 
/* 连 接 数 据 库 */ 
function connect() ( // 连 接 信息 
global $mysqlhost, $mysqluser, $mysqlpwd, $mysqldb; // 连 接 信息 
if ($this-»obj['persistent'])( 
$this-»connection id = mysql pconnect( $mysqlhost , 
$mysqluser ,$mysqlpwd ); )//Xéf ID 
else ( 
$this-»connection id - 
mysql connect( $mysqlhost ,$mysqluser ,$mysqlpwd); 


) 
if ( !mysql select db($mysqldb, $this-»connection id) ) ( 
echo ("ERROR: Cannot find database ".$mysqldb); 
F} 
/* 处 理 查询 */ 


function query($the query) ( 
$this-»query id = mysql query($the query, $this-»connection id); 
if (! $this-»query id ) ( 
$this-»fatal error ("mySQL query error: $the query"); 
5 
return $this-»query id; 
H 
/* 处 理 查询 */ 
function queryValue ($query, $i, $fieldName) ( 
if(mysql result ($query, $i, $fieldName)) { 
return mysql result ($query, $i, $fieldName); 
} 
else( 
return ""; 
H 


/* 在 最 后 一 个 查询 的 基础 上 取 第 一 排 */ 
function fetch row ($query id = "") {// 搜 索 显示 一 条 记录 信息 
Taecry idi yer 
$query id = $this->query id; 


4 
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Sthis->record row = mysql fetch array ($query id, MYSQL ASSOC); 
return $this-»record row;// 

b 
function getRow($sql) {// 获 取 行 
$res-mysql query($sql,$this-»connection id);//resourse 
if(!$res)( 

echo mysql error(); 

return; 
) 
$result-mysql fetch array($res,MYSQL ASSOC); 
return $result; 


/* 在 最 后 一 个 查询 的 基础 上 取 第 一 排 */ 
function fetch object ($query id = "") ( 
return mysql fetch object ($query id) ; 


} 
/* 在 最 后 一 个 查询 的 基础 上 取 第 一 排 */ 
function getAll($sql,$gettype-MYSQL ASSOC)( 
$result = array(); 
$this->query id=mysql query ($sql, $this->connection id); 
if (! $this->query id ){ 
$this->fatal error ("mySQL query error: $the query"); 
) 
while($row-mysql fetch array($this-»query id,$gettype))( 
$result[]-$row; 
) 
return $result; 
) 
// 由 过 去 的 查询 的 行 中 取 数 
function get affected rows() ( 
return mysql affected rows($this-»connection id); 
) 
// 取 结果 中 的 行 数 集 
function get num rows() ( 
return mysql num rows($this-»query id); 


} 
/* 取 最 后 插入 的 ID 从 SQL 自动 增 量 */ 
function get insert id() { 
return mysql insert id(Sthis->connection id); } 
/* 返 回 查 询 的 使 用 量 */ 
function get query cnt() ( 
return $this-»query count; 


/ * 3E Ili mySQL 内 存 的 结果 集 */ 
function free result ($query id-"") { 
if ($query id = "") ( 
$query id = $this-»query id; 
l 
Gmysql free result ($query id); 
) 


/* 关闭 数据 库 */ 
function close db() ( 
return mysql close($this-»connection id); 
} 
/* 返 回 一 个 数组 的 表 */ 
function get table names() { 
$result = mysql list tables ($this->obj['sql database']); 
$num tables = @mysql_numrows ($result); 
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for ($i = 0; $i < $num tables; $i++){ 
$tables[] = mysql tablename ($result, $i); 
} 
mysql free result ($result); 
return $tables; 


/* 返 回 一 个 字段 的 数组 */ 
function get result fields($query id-"") ( 
if ($query id -- "")( 
$query id - $this-»query id; 
H 
while ($field = mysql fetch field($query id))( 
$Fields[] = $field; 
) 
return $Fields; 


/* 基 本 误差 的 处 理 程序 */ 
function fatal error($the error) ( 
if ($this-»return die == 1) ( 
$this-»error - mysql_error (); 
return TRUE; 
} pr 
$db-new db_driver () ;// 实 例 化 
$db-»connect () ; // 连 接 信息 
$db-»query("set names utf8"); // 选 择 字符 集 
$sql="select * from ".$TableConfig." where id-1"; 
$config row-$db-»getRow($sql); 
TE 


今天 同事 B 完成 了 数据 库 设计 的 全 部 工作 。 我 知道 电子 商务 平台 是 常见 的 平台 ， 越 来 
越 多 的 人 在 开发 和 重视 电子 商务 平台 ， 对 于 数据 库 设计 的 要 求 也 越 来 越 高 ， 它 不 只 是 停留 
在 表 之 间 内 部 的 关系 ， 最 重要 的 是 表 与 表 之 间 的 关系 、 数 据 库 管理 、 数 据 备份 还 原 安全 等 
问题 ， 我 通过 两 天 对 电子 商务 的 研究 ， 了 解 了 国人 的 使 用 习惯 ， 顺 利 完 成 了 数据 库 的 开发 。 
总 结 完毕 后 ， 我 决定 早点 休息 ， 为 明天 的 工作 养 精 蓄 锐 。 


7.4 前 台 设 计 
2009 年 6 月 28 9, #04 


刚刚 结束 了 数据 库 设 计 工作 ， 这 也 宣告 整个 项 目的 前 期 工作 已 经 完成 。 接 下 来 将 进入 
正式 设计 和 编码 阶段 。 首 先 需 要 完成 前 台 页 面 的 设计 工作 ， 此 任务 是 由 同事 C 负责 完成 的 。 


7.4.1 用 户 注册 和 登录 管理 


在 电子 商务 管理 系统 中 ， 用 户 注册 和 登录 管理 十 分 重要 ， 这 些 信 息 的 丢失 会 导致 难以 
估计 的 损失 ， 所 以 在 设计 时 ， 一 定 要 考虑 到 多 方面 的 因素 ， 下 面 将 详细 讲解 。 


————————— —————————————————— HÓA >g 


$ 
S 深入 体验 PHP RAFE — 


1. 用 户 注册 
用 户 要 在 商城 里 交易 ， 必 须 拥 有 一 个 属于 自己 的 账户 和 密码 ， 只 有 这 样 ， 才 能 正常 成 
功 交 易 ， 如 图 7-3 所 示 。 
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图 7-3 注册 页 面 


下 面 通过 一 段 代 码 进行 讲解 ， 其 代码 (Gegisterphp) 如 下 : 


«?php defined(" ACCESS ") or die('Restricted access'); ?> 
«link href-"«?php-$SETUPFOLDER?»/modules/register/css/style.css" 
rel="stylesheet" type="text/css"> 
<table width="100%" border="0" cellspacing="0" cellpadding="0"> 
<tr> 
<td width="5" height="6" class="box top left"> 
<img src="<?php=$SETUPFOLDER?>/images/box top left.gif" /»«/td» 
«td class-"box top bg"»&nbsp;«/td» 
«td width-"5" class="box top right"»«/td» 
«/tr» 
«tr» 
«td class-"box left"»5&nbsp;«/td» 
«td class-"register container"» 
«script language-"javascript"» 
function send request get reg(url) ( 
create request(); // 创 建 请 求 
http request.onreadystatechange = 
processCheckUsername; //http 地 址 
http request.open ("GET"，url，true) ;// 请 求 打开 
http request.send (nul1) ;// 请 求 收发 
} 
function 
send request post reg(url,querystring,func) ( 
create request (); 
if(func--'reg') http request.onreadystatechange = processReg; 


http request.open("POST", url, true); //W RIF 

http request.setRequestHeader ("Content-Type"," 
application/x-www-form-urlencoded"); 

http request.send (querystring) ; 
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function processReg() { 
var form-document.getElementById ("forml"); 
if (http request.readyState == 4) ( 
if (http request.status == 200) ( 
if(http request.responseText--1) 
t 
location-'«?php-$SETUPFOLDER?»/index.php?menuid- 
12&level-2&flag-reg'; 
H 
if(http request.responseText--2) ( 
alert('Username exsit please change it! '); 
) 
if(http request.responseText--3) ( 
alert('Enter Validate code error! '); 
) 
) else ( // 页 面 不 正常 
alert ("error"); 
))r 
function checkReg() {// 检 测 注册 
Var form-document.getElementById ("forml"); 
if(form.validate code.value.length!-4) {// 检 查验 证 码 
alert ("验证 码 必须 是 4 位 1"); 
form.validate code.focus(); 
return; 
) 
if(!isCharVar(form.reg username.value) llform.reg username.value.length 
«3||form.reg username.value.length»15) {// 检 验 用 户 名 
alert ("用 户 名 3 - 15 字符 !"); 
form.reg username.focus(); 
return; 
) 


if(form.reg psw.value.length«6||form.reg psw.value.length»15) ( 

alert ("密码 6 - 15 字符 和 数字 !") ; // 检 查 密码 
form.reg psw.focus(); 
return; 

H 

if(form.reg psw.value!-form.reg pswl.value) {// 输 入 密码 检查 
alert ("两 次 输入 密码 不 一 致 !") 
form.reg pswl.focus(); 
return; 

b 

if(!isEmail(form.EmailName.value)) {// 邮 箱 检验 
alert (" 请 输入 有 效 的 邮箱 地 址 !") ; 
form.EmailName.focus(); 
return; 


b 
var sex-1; 


if(form.sex[1].checked) sex-2; 
querystring-"username-"«form.reg username .value+"&psw="+form.reg psw 
.value+"&EmailName="+form.EmailName .value+"&sex="+sex+"&validate code= 
"+form.validate code.value; 
send request post reg ('<?php=$SETUPFOLDER?>/ajax/ 
reg.php',querystring, "reg"); 
b 
function checkUsername() {// 检 测 用 户 名 
var form-document.getElementById ("forml"); 
if(form. reg username.value--"")( 
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alert ("iff AH & 1") ; 
form.reg username.focus(); 
return; 
) send request get reg(' 
«?php-$SETUPFOLDER?»/ajax/checkusername.php?username-'-«form.reg username 
-Value) 
} 
function processCheckUsername() {// 检 查 用 户 名 
if (http request.readyState == 4) { 
if (http request.status == 200) ( 
if(http request.responseText--2) 
t 
alert ("用 户 名 已 经 存在 ! n); 
} 
if(http request.responseText--1) 
t 
alert (' 用 户 名 可 用 1); 
} 


} else { 
alert ("page error!"); 
} 


} 
</script> 
<table border="0" class="register table" cellpadding="0" 
cellspacing="0" width="100%"> 
<tr class="register tr"> 
«td class-"register td title"> 验 证 码 
<span class="star">*</span>:</td> 
«td class-"register td box"> 
<input class="register box" style="float:left;" name="validate code" 


type="text" id="validate code" size="4" maxlength= /> 
<img 
src='<?php=$SETUPFOLDER?>/include/validateCode.php'> 
«/td» 


«/tr» 
«tr class-"register tr"» 
«td class-"register td title"> 用 户 名 
<span class="star">*</span>:</td> 
<td class="register td box"> 
<input name="reg username" class="register box" type="text" 
id="reg username" style="WIDTH: 185px" /> 
<input type="button" class="register button" 
onclick-"checkUsername()" value=" 检 查 用 户 名 " /»«/td» 
«/tr» 
«tr class-"register tr"> 
«td class-"register td title"> 密 码 
«span class-"star"»*«/span»:«/td» 
«td class-"register td box"» 
«input class-"register box" name-"reg psw" type-"password" id-"reg psw" 
Style-"WIDTH: 185px" /»«/td» 
«/tr» 
«tr class-"register tr"> 
«td class-"register td title"> 重 新 输入 密码 
<span class="star">*</span>:</td> 
<td class="register td box"> 
«input class="register box" name-"reg pswl" type="password" id-"reg pswl" 
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style="WIDTH: 185px" /»«/td» 


</tr> 
<tr class="register tr"> 
«td class-"register td title"> 邮 箱 地 直 <span class="star">*</span>:</td> 
«td class-"register td box"»«input class-"register box" 
name-"EmailName" type-"text" id-"EmailName" style-"WIDTH: 185px" /»«/td» 


«/tr» 
«tr class-"register tr"> 
«td class-"register td title"> 性 别 :</td> 
<td class="register td box"><?php 
for ($i=1;$i<=count ($T Gender) ; $i++) { 
if((int)$sex--$i|| (empty ($sex) &&$i==1) ) 
echo "<input name='sex' type='radio' checked 


value='".$i."'>".$T Gender[$i]; 
else 
echo "<input name='sex' type='radio' 
value='".$i."'>".$T Gender[$i]; 
} 
?»«/td» «/tr» 
«tr class-"register tr"> 


«td colspan-"2" align="center"> 
«input type-"button" class-"register button" value=" 提 交 " 


onclick-"checkReg()" /> 
«/td» «/tr» 
«/table» «/td» 
«td class-"box right"»&nbsp;«/td» 


«/tr» «tr» 
«td height-"6" class="box bottom left"»«/td» 


«td class-"box bottom bg"»&nbsp; «/td» 
«td class="box bottom right"»«/td» 


«/tr» 
«/table» 


2. 用 户 登 录 页 
用 户 拥有 账户 后 就 可 以 登录 系统 并 进行 交易 ， 如 图 7-4 所 示 为 用 户 登录 页 的 界面 。 


ND MES " k 


74 用 户 登录 页 


下 面 通过 一 段 代码 进行 讲解 ， 其 代码 (loginphp) 如 下 : 


» 
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<?php defined(" ACCESS ") or die('Restricted access'); ?> 
«?php 
?» 
«link href-"«?php-$SETUPFOLDER?» /modules/login/css/style.css" 
rel="stylesheet" type="text/css"> 
<?php 
if(!isLogin()) 
{ 
B 
«table class-'login container' width-"100$" border-"0" cellspacing-"0" 
cellpadding-"0"» 
«tr» 
«td width-"5" height-"6" class-"box top left"» 
«img src-"«?php-$SETUPFOLDER?»/images/box top left.gif" /»«/td» 
«td class-"box top bg"»&nbsp;«/td» 
«td width-"5" class-"box top right"»«/td» 
«/tr» 
«tr» 
«td class="box left"»&nbsp;«/td» 
«td class-"login container"» 
«script language-"javascript"» 
function send request post checkuser (url,querystring, func) 


create request(); 
if(func--'login') http request.onreadystatechange - 
processLogin; 
if (func--'forgetPassword') 
http request.onreadystatechange - processForgetPassword; 
http request.open("POST", url, true); 
http request.setRequestHeader ("Content-Type"," 
application/x-www-form-urlencoded"); 
http request.send(querystring); 
) 
function processLogin() ( 
var form-document.getElementById ("formi"); 
if (http request.readyState A ET 
if (http request.status == 200) ( 
if(http request.responseText--1)( 


top.location-'«?php-$SETUPFOLDER."/".$dispatch page?»?menuid-12&1level-2& 
flag-logined'; 
H 
if(http request.responseText--2) ( 
alert (' 用 户 名 或 密码 错误 ! t); 
1 
) else ( // 页 面 不 正常 
alert ("error"); 
b ded 
function checkLogin() ( 
var form-document.getElementById ("forml"); 
if(form.username.value--"") ( 
alert ("请 输入 用 户 名 !") ; 
form.username.focus (); 
return; 
} 
if(form.psw.value--"")( 
alert (" 请 输入 密码 !") ; 
form.psw.focus():; 
return; 
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} 
querystring="username="+form.username .value+" &psw="+form.psw.value; 


send request post checkuser('«?php-$SETUPFOLDER?»/ajax/login.php',querys 
tring,"login"); 
) 
</script> 
<span> 用 户 登录 </span> 
«p» 用 户 名 : «input class-"login input box" type-"text" name-'username' 
id-"username" /» «br /» 
<p> 密 码 gnbsp; gnbsp;: <INPUT class-"login input box" type-'password' 
name-'psw' id-"psw"»«/p» 
«span»«input type="button" class-"login button" value=" 登 录 " 
onclick-"checkLogin()" /»«/span» «br /»«span» 
<A hre «?php-$SETUPFOLDER."/"/$dispatch page?» 
?menuid=10&level=2"> 忘 记 密码 ? 
«/A»&nbsp; &nbsp; &nbsp; &nbsp; «A 
href-"«?php-$SETUPFOLDER."/".$dispatch page?» 
?menuid-11&1level-2"»5jlJll !«/A»«/span» 
«/td» 
«td class-"box right"»&nbsp;«/td» 
«/tr» 


"6" class="box bottom left"»«/td» 
box bottom bg"»&nbsp;«/td» 

«td class="box bottom right"»«/td» </tr> 
«/table» 
«?php 
) 
?> 


3. 忘记 密码 
在 使 用 的 过 程 中 ， 难 免 有 用 户 忘记 密码 ， 程 序 员 必须 要 保证 安全 的 情况 下 找 回 密码 ， 
本 系统 在 注册 时 要 输入 自己 的 邮箱 ， 如 果 忘 记 密 码 ， 系 统 可 发 送 一 封 邮 件 告 知 用 户 其 信息 ， 
如 图 7-5 所 示 。 
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下 面 通过 一 段 代 码 进行 讲解 ， 其 代码 (forgetpassword.php) 如 下 : 
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<?php Php defined(" ACCESS ") or die('Restricted access'); ?> 
«table class-'login container' width-"100$" border-"0" cellspacing-"0" 
cellpadding-"0"» 
«tr» «td width-"5" height-"6" class-"box top left"» 
«img src-"images/box top left.gif" /»«/td» 
«td class-"box top bg"»&nbsp;«/td» 
«td width-"5" class-"box top right"»«/td» 
«/tr» 
«tr» 
«td class="box left"»&nbsp;«/td» 
«td class-"login td"» 
<script language-"javascript"» 
function send request post checkuser (url,querystring, func) 
t 
create request (); 
if(func--'login') http request.onreadystatechange = processLogin; 
if(func--'forgetPassword') http request.onreadystatechange - 
processForgetPassword; 


http request.open("POST", url, true); 
http request.setRequestHeader ("Content-Type"," 
application/x-www-form-urlencoded"); 
http request.send(querystring); 
) 
function processForgetPassword() ( 
var form-document.getElementById ("forml"); 
if (http request.readyState == 4) ( 
if (http request.status == 200) ( 
if(http request.responseText--1) 
t 
alert (' 您 的 密码 已 经 送 入 您 的 注册 邮箱 ! '); 
} 
ats (http request.responseText--2) ( 


alert (' 用 户 名 错误 ,请 重新 输入 ! 1); 


} 
if(http request.responseText==3) { 
alert (' 您 的 注册 邮箱 无 效 请 联系 管理 员 ! 1); 
} 
} else { // 页 面 不 正常 
alert ("error"); 
22] 
function checkForgetPassword() {// 检 测 密码 
Var form-document.getElementById ("forml"); 
if(form.psw username.value--"")( 
alert ("iif AJH P 4&1"); 
form.psw username.focus(); 
return; 
} 
querystring="psw_username="+form.psw_username .value; 
send request post checkuser ('<?php=$SETUPFOLDER?>/ajax/forgetpass.php', 
querystring,"forgetPassword"); 


</script> 
<span > 您 的 密码 将 会 送 到 您 的 邮箱 </span> 
«p» 
用 户 名 : «input class-"login input box" type="text" name-'psw username" 
id-"psw username" /» «br /» 
span class-"main-box-bg"» 
«input type-"button" class-"button" value=" 发 送 " 
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onclick="checkForgetPassword()" /> 
</span><br /> </p> 
«td class-"box right"»&nbsp;«/td» 
tro ctr 
«td height-"6" class-"box bottom left"»«/td» 
«td class-"box bottom bg"»&nbsp;«/td» 
«td class="box bottom right"»«/td»«/tr» 
</table> 


7.4.2 ”产品 展示 
在 商城 的 前 台 页 面 中 ， 向 浏览 者 展示 产品 也 十 分 重要 ， 如 图 7-6 所 示 为 产品 展示 界面 。 


聚拢 型 文 移 10050A 和 


购物 车 
购 构 车 产品 数 0 


市 场 价格 99095 
当前 价格 “89.00 $ 
添加 到 风 和 车 

搜索 
产品 分 类 
3 
8 C) 女士 内 家 
9 C) cH » 
son Jemi: 


品牌 ， 姐妹 花 
图 7-6 产品 展示 
下 面 通过 一 段 代 码 进行 讲解 ， 其 代码 (product3.php) 如 下 : 


«?php defined(" ACCESS ") or die('Restricted access'); ?> 
«link href-"«?php-S$SETUPFOLDER?»/modules/product/css/style.css" 
rel-"stylesheet" type-"text/css"» 
«table width-"100$" border-"0" cellspacing-"0" cellpadding-"0"» 
«?phpphp 
$sql-"update ".$TableEb product." set click count-click count+1 
where id-".$id; 
$db-»query ($sql); 
$sql-"select 
".$TableEb product.".* ,".$TableEb product category.".name as 
product category name from 
".STableEb product." ,".$TableEb product category." Where 
".$TableEb product.".eb product category id = 
$TableEb product category.".id and 
".$TableEb product.".id-".$id; 
S$row-$db-»getRow ($sql); 


s 
«tr» 
«td class-"product details img td" align="center"> 
«?php 
if(!empty($row['picture'])) ( 
[9 


«a target-" blank" 
href-"«?php-$SETUPFOLDER?»/upload/eb product/«?php-$row['picture']?»" > 
«img width-"«?php-$config row['product picture width']?»" height-"«?php- 

$config row['product picture height']?»" 
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src-"«?php-$SETUPFOLDER?»/upload/eb product/«?php-$row['picture']?»" 
border-"0" /»«/a» 
«?phpphp ) 
?»«/td» 
«td valign-"top" class-"product details text"» 
«span class-"product details title"> 产 品 分 类 </span> : 
«?php-$row['product category name']?» 
«br /» 
«span class-"product details title"> 产 品名 称 </span> : 
«?php-$row['product name']?» 
<br /> 
«span class-"product details title"> 市 场 价格 </span> 
«del»«?php-$row['market price']?> 
«?php-$T Price type[Sconfig row['price type']]?></del> 
<br /> 
<span class="product details title"> 当 前 价格 </span> : 
<?php=$row['price']?> 
«?php-$T Price type[$config row['price type']]?> 
«br /» 
«div class-"product addcartbutton div"» 
«input type="button" class-"button" onclick-"addCart («?php-$row['id']?»)" 
value=" 添 加 到 购物 车 " /> 


</div> «/td» 
</tr> «tr» «td colspan-"2"»&nbsp;«/td» 
</tr> «tr» «td colspan-"2"» «?php-$row['content']?» «/td» 
«/tr»«tr» 
«td align-"center"»«/td» 
«td align="center"> «/td» «/tr» </table> 


<script language="javascript"> 
function addCart (id) 


{location="<?php=$SETUPFOLDER?>/product .php?menuid=202&level=2&product id 
="+id; } 
</script> 


1. 购物 车 


在 前 台 页 面 中 ， 购 物 车 十 分 重要 ， 它 将 需要 的 产品 放置 在 一 起 ， 统 一 下 订单 ， 并 实现 
统一 付款 的 方式 。 具 体 效果 如 图 7-7 所 示 。 


PREE as D anto 


Piso 54:05 


图 7-7 购物 车 
下 面 通过 一 段 代码 进行 讲解 ， 其 代码 如 下 : 
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<?php defined(" ACCESS ") or die('Restricted access'); ?> 
«link href-"«?php-$SETUPFOLDER?»/modules/product cart/css/style.css" 
rel="stylesheet" type="text/css"> 
«div class-"product cart container"» 
«?php 
if(!empty($product id)) ( 
$sql-"select * from ".$TableEb product." where id-".$product id; 


// 获 取 数据 
$row-$db-»getRow ($sq1) ;// 获 取 数 据 
$b-false; 
for($i-1;$i«-(int)getMyCookie('cookie num'); $i++) { 
if ($product id==getMyCookie ("cart".$i." productid")) { 


setMyCookie ("cart".$i." quantity", (int)getMyCookie ("cart".$i. 
"quantity")+1);// 保 存 缓存 
$b=true; 
break; 
) 
) 
if($b--false) 1 
$cookie num-getMyCookie('cookie num'); if (empty ($cookie num)) 


setMyCookie ('cookie_num',1);// 保 存 缓存 
setMyCookie("cartl productid", $row['id']);// 保 存 缓存 ID 号 
setMyCookie("cartl product name", $row['product name']); 
// 保 存 缓存 物品 名 称 
setMyCookie("cartl quantity",1);// 保 存 缓存 数量 
setMyCookie("cartl price", $row['price']);// 保 存 缓存 价格 
} 
else { 
$cookie num-(int)getMyCookie('cookie num')-«1;//3kWUA (P3 
setMyCookie('cookie num',$cookie num) ; // 获 取 缓 存 数据 
setMyCookie ("cart".$cookie num." productid",$row['id']); 
// 获 取 缓存 数据 ID 号 
setMyCookie ("cart".$cookie num." product name", 
$row['product_name" ]) ;// 获 取 物 品名 称 
setMyCookie ("cart".$cookie num." quantity",1) ;// 获 取 缓 存 数量 
setMyCookie ("cart".$cookie num." price",$row['price']);// 获取 
缓存 价格 
) 


) 
header("location: ".$SETUPFOLDER."/product.php?menuid-202&1evel-2 "); 


"editcart")( 
;$i«-(int)getMyCookie('cookie num');$i-*) ( 


setMyCookie ("cart".$i." quantity", (int)$ POST["quantity".$i]); 
$ 
header("location: ".$SETUPFOLDER."/product.php?menuid-202&1evel-2 "); 
} 
if ($status=="clearcart") { 
setMyCookie('cookie num',time()-300); 
for($i-1;$i«-(int)getMyCookie('cookie num'); $i++) ( 
setMyCookie ("cart".$i." productid",time()-300); 
setMyCookie("cart".$i." product name",time()-300); 
setMyCookie("cart".$i." quantity",time()-300); 
setMyCookie("cart".$i." price",time()-300); } 
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header ("location: ".$SETUPFOLDER."/product.php?menuid-202&1level-2 ");} 
if($status=="removecart"){ 


// 将 剩 下 的 产品 导入 到 新 的 cookie 里 面 ,删除 选择 的 cookie 


$j=1; 
for($i-1;$i«-(int)getMyCookie('cookie num');$i++) ( 
if((int)$remove id--$i) { 
setMyCookie ("cart".$i." productid",time()-300); 
setMyCookie ("cart".$i product name",time()-300); 
setMyCookie ("cart".$i." quantity",time()-300); 
setMyCookie ("cart".$i." price",time()-300); ) 
else i 


setMyCookie ("cart".$j." productid",getMyCookie ("cart".$i." productid")); 


setMyCookie("cart".$j." product name",getMyCookie("cart".$i." product 
name")); 


setMyCookie ("cart".$j." quantity",getMyCookie ("cart".$i." quantity")); 


setMyCookie ("cart".$j." price",getMyCookie("cart".$i." price")); 
$j++; } 
$cookie num-(int)getMyCookie('cookie num')-1; 
setMyCookie('cookie num',$cookie num); 
header("location: ".$SETUPFOLDER."/product.php?menuid-202&level-2 "); 
) 
?> «table width-"100$" border-"0" cellspacing-"1" cellpadding-"0"» 
«tr class-"product cart trl"» 
«td height-"25" align="center"> 产 品名 称 </td> 
«td align="center" > 数量 </td> 
«td align="center" > 价格 </td> 
«td align="center"> 总 价格 </td> 
«td align-"center"»&nbsp;«/td» 
«/tr» 
<?php 
$total=0; 
$totalprice-0; 
$catnum-0; 
$cookie num-getMyCookie('cookie num'); 
if(!empty($cookie num)) 
$catcookie num-getMyCookie('cookie num'); 
for($i-1;$i«-(int)getMyCookie('cookie num');$i++) 
t 
$total4- (int)getMyCookie ("cart".$i." quantity"); 


$rowTotalPrice- (int)getMyCookie ("cart".$i." quantity")*getMyCookie(" 
cartr. Sian prico)? 
$totalprice+=$rowTotalPrice; 
?> 
<tr class="product cart tr2"> 
<td height="25" align="center"><?php=getMyCookie 
("cart".$i." product name")?»&nbsp;«/td» 
«td align-"center" ><input name="quantity<?php=$i?>" 
type="text" id="quantity" 
style-"width:40px; height:18px; border:lpx solid #D4D0C8;" 
value-"«?php-getMyCookie ("cart".$i." quantity")?»"»«/td» 


«td align-"center"»«?php-getMyCookie ("cart".$i." price")?» 
«?php-$T Price type[$config row['price type']]?»«/td» 
«td align-"center"»«?php-$rowTotalPrice?» 


«?php-$T Price type[$config row['price type']]?»«/td» 
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<td align="center" > 
«a href-"javascript:removecart («?php-$i?») "> 删除 </a></td> </tr> 
<?php ] Wes 
«td height-"25" colspan-"6" align-"right" class-"stylel4" 
style-"font-weight:bold; padding-right:26px; padding-top:5px; "> mA: 
«?php-$total?» ， 总 价 : «?php-$totalprice?» 
«?php-$T Price type[$config row['price type']]?» </td> 
«/tr» 
«/table» 
«div style-"height:30px; text-align:center;"» 
«input type-"button" value=" 修 改 " class-"button" onclick-"editcart()" /> 
«input type-"button" value=" 结 算 " onclick-"checkout ()" 
class-"button" /> 
«/div» 
«input type="hidden" name-"remove id" /> 
«input type-"hidden" name-"status" Value=""> 
«/div» 
«script language-"javascript"» 
function editcart ()( 
form-document.getElementById('forml'); 
form.status.value-"editcart"; 
form.submit ();} 
function checkout (){ 
location-"«?php-$SETUPFOLDER?»/product.php?menuid-203&1evel-2"; } 
function clearcart()( 
form-document.getElementById('forml'); 
form.status.value-"clearcart"; 
form.submit();) 
function removecart(i ( 
form-document.getElementById('forml'); 
if(confirm("Do you want to deleter this product ?" 
return; 
form.status.value-"removecart"; 
form.remove id.value-i; 
form.submit();) 


--false) 


</script> 
2. 产品 种 类 的 管理 
产品 种 类 至 关 重 要 ， 它 是 将 商城 中 的 产品 分 类 别 进 行 管 理 ， 便 于 浏览 者 更 加 及 时 地 找 


到 需要 的 产品 。 下 面 通过 一 段 代码 进行 讲解 如 何 进 行 产 品 分 类 , 其 代码 (popup_category.php) 
如 下 
«?php defined(" ACCESS ") or die('Restricted access'); ?> 
<link href-"«?php-$SETUPFOLDER?»/modules/product category/css/style.css" 
rel-"stylesheet" type-"text/css"» 
«div class-"left product category container"» 
«?php 
$sql-"select a.*,2 as page level from ".$TableEb product category." as a 
where  a.is show-1 and a.pid-0 order by a.sortid" ; 
$result nav-$db-»getAll ($sql); 
$nav count=count ($result nav); 
$dispatch page-"product.php"; 
$menuid-"201"; 


if($nav count»0) ( 
?> «div id-"leftproduct menu ddsidemenubar" class-"markermenu"» 


«ul» 
<?php // 您 好 
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$nav nodepath-""; 
for ($k=0;$k<$nav count; $k++) 
{ $link url=$SETUPFOLDER."/".$dispatch page."?menuid-".$menuid."&pcatid 
= rosult nav[Sk]lp'ud"1-"&level-" 
.$result nav[$k] ['page level']; 
$nav nodepath.-$result nav[S$k]['id'].","; 
// 检 查 节点 
$rel-"";if($result nav[Sk] ['is leaf']==2) 
$rel-"rel-'ddsubmenuside".$result nav[$k]['id']."'"; 
?» 
«li «?php-$rel?»»«a target- 
"«?php-$T Link method[$result nav[$k]['link method']]?»" 
href-"«?php-$link url?»"»«?php-$result nav[$k]['name']?»«/a»«/li» 
if(!empty($nav nodepath)) 
t 


$nav nodepath-substr($nav nodepath,0,strlen($nav nodepath)-1); 
?> 
«/ul» 
«/div» 
«script type-"text/javascript"» 
ddlevelsmenu.setup("leftproduct menu ddsidemenubar", "sidebar") 
</script> 
<?php 
// 子 菜单 
if(!empty(Snav nodepath)) { 
$nav nodepath array-explode(',',$nav nodepath); 
$where-" a.is show-1 and a.pid«»0 and "; 
$nav nodepath count-count ($nav nodepath array); 
//reomve current category 
for($k-0;$k«$nav nodepath count;$k++) { 
$where.-" a.id«»".$nav nodepath array[$k]." and "; 
) 


$where.-" ("; 
for($k-0;$k«$nav nodepath count-1;$k++) 
t 


$where.-" FIND IN SET('".$nav nodepath array[$k]."',a.nodepath)»0 or"; 
) 
$where.-" FIND IN SET 
('".$nav nodepath array[$nav nodepath count-1]."',a.nodepath)»0)"; 
$sql-"select a.*,2 as page level from 
".$TableEb product category." as a where ".$where." order by a.sortid" ; 
$resultCategroy-$db-»getAll ($sql); 


for($k-0;$k«$nav nodepath count;$k++) 
t 
$level num-1; 


subNavLeftProductCategory ($resultCategroy, $nav nodepath array[$k], $k); 
) 
b 
2> 
«?php 
} 
function subNavLeftProductCategory ($resultCategroy, $kd, $kndex) { 
global $level num,$dispatch page,$T Link method, $menuid, $level num flag, $flag, 
$nav nodepath array, $SETUPFOLDER; 
if ($level num!-1&&$level num flag--$1level num) fi 
echo "«ul»"; 
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} 
$level nume; 
if ($level num--2) { 
echo "<ul id-'ddsubmenuside".$nav nodepath array[$kndex]."" 
class-'ddsubmenustyle blackwhite'»"; 
} 
$level num flag=$level num; 
for ($k=0; $k<count ($resultCategroy); $k++) { 
$link url=$SETUPFOLDER."/".$dispatch page."?menuid-".$menuid."&pcatid-". 
$resultCategroy[$k]['id']."&level-" 
-$resultCategroy[$k]['page level']; 
if($kd--$resultCategroy[$k] [pid]) { 
if ($resultCategroy[$k] ['is leaf']==2) T 
echo "<li><a target-'".$T Link method[$resultCategroy[$k]['link method']]. 
"'href-'".$link url."'»".$resultCategroy[$k] ['name'] . "«/a»"; 
) 
else t 
echo "<li><a target-'".$T Link method[$resultCategroy[$k] ['link method']]. 
"'href-'".$link url."'»".$resultCategroy[$k] ['name'] . "«/a»«/1i»"; 
} 
if($resultCategroy[$k]['is leaf']--1) continue; 


subNavLeftProductCategory ($resultCategroy, $resultCategroy[$k] [id], 
$kndex) 7 
) 

$level num--; 

echo "</ul>"; 

) 
?» 
«/div» 


| 

历经 4 天 ， 同 事 C 完成 了 基本 信息 管理 模块 的 工作 。 此 阶段 的 核心 是 购物 车 的 处 理 ， 
这 才 是 整个 购物 系统 的 核心 模块 。 多 亏 网 络 上 有 很 多 成 熟 的 解决 方案 ， 同 事 C 顺利 地 完成 
了 工作 。 看 来 网 络 也 很 重要 ， 有 问题 可 以 尝试 从 网 络 中 获取 答案 。 至 此 ， 我 们 的 项 目 还 没 
有 结束 ， 还 要 继续 完成 后 台 的 管理 工作 。 


在 过 去 的 几 天 里 ， 同 事 C 完成 了 基本 信息 管理 模块 的 工作 。 在 他 进行 编码 的 同时 ， 我 
们 同时 也 开始 了 系统 后 台 模 块 的 编码 工作 。 此 阶段 的 工作 主要 是 编写 PHP 程序 ， 对 界面 美 
观 方面 的 要 求 不 是 很 高 ， 这 同 前 台 设 计 有 很 大 的 区 别 。 


7.5.1 添加 新 商品 


商城 购物 系统 中 ， 随 着 时 间 的 推移 ， 会 需要 不 断 地 添加 新 商品 ， 和 超市 进货 一 样 ， 总 
有 许多 新 产品 不 断 地 上 架 ， 在 这 个 系统 中 也 一 样 ， 下 面 通过 一 段 代码 进行 讲解 ， 其 代码 
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(eb_productadd.php) 如 下 : 


<?php Php require "../../db/Connect.php"?> 
<?php Php include "../../include/authorizemanager.php"?» 
«?phpphp 
// 添 加 
$status-$ POST['status']; 
if(S$status--"add") ( 
$indate-date('Y-m-j H:i:s'); 
$eb product category id-$ POST['eb product category id'];// 产 品 分 类 
$product name-$ POST['product name'];// 产 品名 称 
$market price-$ POST['market price'];// 市 场 价 格 
$price=$_POST['price'];// 当 前 价格 
$price type-$ POST['price type'];// 当 前 价格 货币 
$keywords=$ POST['keywords']; 
$quantity-$ POST['quantity'];// 数 量 
$is verify=$_POST['is verify'];// 审 核 
$is_recomend="1";// 是 否 推 荐 
$featured=$ POST['featured'];// 推 荐 
$content-$ POST['content'];// 描 述 
$publish people=$ SESSION['SessionAdminUser']['username'];// 发 布 人 
$publish time=$indate;// 发 布 时 间 
$picture-$ POST['picture'];// 商 品 图 片 
$click_count="0";// 单 击 数 
$remark_count="0";// 评 论 数 
$file name = $ FILES["file"]['name']; 
$picture-substr($file name, strrpos ($file name,'.'), 
strlen ($file name)-strrpos ($file name, '.')); 
if (!empty ($picture)) 
$picture-getRandomNum().$picture; 
$sgl-"insert into 


".$TableEb product." (keywords,eb product category id,product name,market 
price,price,quantity,is verify,is recomend, featured, content, publish people, 
publish time,picture,click count,remark count)values('".$keywords."', 
".$eb product category id.",'".$product name."',".$market price.", 
".$price.",".$quantity.",".$is verify.",".$is recomend.",".$featured.", 
'".$content."','".$publish people."','".$publish time."','".$picture."', 
".$click count.",".$remark count.")"; 

$query-$db-»query ($sq1) ; 

if (!empty ($file name)) 

{ 


$FileName=$UploadPath."upload/eb product/".$picture; 
$file = $ FILES['file']['tmp name']; 
if (copy ($file, $FileName) ) 
{ 
unlink($file); 
n 
$FileName s-$UploadPath."upload/eb product/s".$picture; 


ImageResize($FileName,$config row['product picture thumbnail width'] 
,$config row['product picture thumbnail height'],$FileName s); 
$message-1; 
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7.5.2 ”修改 商品 信息 


在 电子 商务 的 平台 中 ， 仓 库 的 信息 也 发 生 着 变化 ， 当 某 一 种 产品 信息 发 生变 化 ， 应 该 
做 到 及 时 修改 。 下 面 通过 一 段 代码 讲解 如 何 实现 修改 商品 信息 ， 其 代码 (eb_productedit.php) 
如 下 : 


<?php require "../../db/Connect.php"?> 
<?php include "../../include/authorizemanager.php"?» 


«?php 
$status-$ POST['status']; 
if($status--"removePic") 1 


$sgl-" select * from ".$TableEb product." where id-".$id; 
$row-$db-»getRow ($sql); 
$FileName-$UploadPath."upload/eb product/".$row['picture']; 


if (file exists ($FileName)) { 

unlink ($FileName); } 
$FileName=$UploadPath."upload/eb product/s".$row['picture']; 
if (file exists ($FileName)) { 

unlink ($FileName); } 


$sql-"update ".$TableEb product." set picture-'' where id-".$id; 
Squery-$db-»query ($591) ; ) 
if($status--"edit") ( 
$indate-date('Y-m-j H:i:s'); 
$eb product category id-$ POST['eb product category id'];// 产 品 分 类 
$product name-$ POST['product name'];// 产 品名 称 
$market price-$ POST['market price'];// 市 场 价格 
$price=$_POST['price'];// 当 前 价格 
$price type-$ POST['price type'];// 当 前 价格 货币 
$keywords=$ POST['keywords']; 
$quantity-$ POST['quantity'];// 数 量 
$is verify-$ POST['is verify'];// 审 核 
$is_recomend="1";// 是 否 推 荐 
$featured=$ POST['featured'];// 推 荐 
$content=$_POST['content'];// 描 述 
$publish people-$ SESSION['SessionAdminUser']['username'];// 发 布 人 
$publish time=$indate;// 发 布 时 间 
$picture=$_POST['picture'];// 商 品 图 片 
$click_count="0";// 单 击 数 
Sremark count="0";// 评 论 数 
$file name = $ FILES["file"]['name']; 
$picture-substr($file name, strrpos ($file name,'.'), 
strlen ($file name)-strrpos($file name,'.')); 
if (!empty ($picture)) 
$picture-getRandomNum().$picture; 
if (!empty ($file name)) 1 
$sql-"update ".$TableEb product." set 
keywords-'".$keywords."',eb product category id- 
".$eb product category id.", product name-'".$product name."', 
market price-".$market price.", 
price-".$price.",quantity-".$quantity.", is Verity=" $ia verify." 
is recomend=".$is recomend.", 
featured=" .$featured.",content='".$content."', 
publish people-'".$publish people."', 
publish time-'".$publish time."', picture-'".$picture."' where id-".$id; 
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$query=$db->query ($sql); 
if ($query) t 
$FileName-$UploadPath."upload/eb product/".$picture; 
$file = $ FILES['file']['tmp name']; 
if (copy ($file, $FileName)) { 
unlink ($file); 


$FileName s=$UploadPath."upload/eb product/s" .$picture; 
ImageResize($FileName,$config row['product picture thumbnail width'] 
,Sconfig row['product picture thumbnail height'],$FileName s); 
) ) ) 
else t 
$sql-"update ".$TableEb product." set keywords-'".$keywords."', 
eb product category id-".$eb product category id.", 
product name-'".$product name."', market price-".$market price.", 
price-".$price.",quantity-".$quantity.", is verify-".$is verify.", 
is recomend-".$is recomend.", 
featured-".$featured.",content-'".$content."', 
publish people-'".$publish people."', 
publish time-'".$publish time."' where id-".$id; 
$query-$db-»query ($sql); ) 
$message-1; } 
$sql-"select * from ".$TableEb product." where id-".$id; 
$row-$db-»getRow($sql);?» 


7.5.8 删除 产品 


电子 商务 的 平台 中 ， 有 时 商品 会 因 种 种 原因 下 架 ， 即 这 种 产品 不 能 再 销售 ， 此 时 需要 
管理 人 员 将 商品 删除 ， 其 实现 代码 (eb_productphp) 如 下 : 


«?phpphp 
// 删 除 
$status-$ POST['status']; 
if ($status==" remove") ( 
$id-$ POST['id']; 
$sql-" select * from ".$TableEb product." where id-".$id; 
$row-$db-»getRow($sql); 
$FileName-$UploadPath."upload/eb product/".$row['picture']; 
if (file exists ($FileName)&&!empty ($row['picture'])) ( 
unlink($FileName); 
) 
$FileName-$UploadPath."upload/eb product/s".$row['picture']; 
if (file exists ($FileName)) ( 
unlink (S$FileName); 
} 


$sql="delete from ".$TableEb product." where id=".$id; 
$query=$db->query ($391) ; 

$sql-"delete from ".$TableEb remark." where eb product id-".$id; 
$query=$db->query ($391) ; 


) 

// 删 除 全 部 

if($status--"removeSelect") { 
Scheckednums-array(); 
$ids-$ POST['ids']; 
$checkednums-explode('.',$ids); 
$filter-""; 
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for($i-0;$i«count ($checkednums) -2; $i++) 
$Sfilter-$filter.$checkednums[$i]." 


) 

Sfilter-$filter.$checkednums [count ($checkednums) -2] .") "; 

$sql=" select * from ".$TableEb product." where id in (".$filter; 
$results-$db-»getAll($sql); 

for($i=0;$i<count ($results);$i++) { 


$FileName=$UploadPath."upload/eb product/".$results[$i]['picture']; 
if (file exists ($FileName)&&!empty ($results[$i]['picture'])) 
unlink($FileName); 
} 


$FileName=$UploadPath."upload/eb product/s".$results[$i]['picture']; 
if (file exists ($FileName)) { 
unlink ($FileName); 
} 
} 
$sql="delete from ".$TableEb product." where id in (".$filter; 
$query-$db-»query ($sql); 
$sql-"delete from ".$TableEb remark." where eb product id in 
(".Sfilter; 
$query-$db-»query ($sql) ; 
) 
// 核 实 
if($status--"verify") ( 
S$checkednums-array (); 
$checkednums-explode('.',$ids); 
$filter-""; 
;$i«count ($checkednums) -27Si++) ( 
$filter-$filter.$checkednums[$i].","; 


$filter-$filter.$checkednums [count ($checkednums) -2] .") "; 

$sql-"update ".$TableEb product." set is verify-1 where id in 
("stilters 

$query=$db->query ($sq1l); 


} 

// 联 合 核实 

if($status--"unverify") ( 
$checkednums-array(); 
$checkednums-explode('.',$ids); 
$filter-""; 
for($i-0;$i«count ($checkednums) -2; $i++) { 

$filter=$filter.$checkednums [$i].","; 


$filter-$filter.$checkednums [count ($checkednums) -2] .") "; 

$sql-"update ".$TableEb product." set is verify-2 where id in 
(".$filter; 

$query-$db-»query ($sql); 


;Si«count ($checkednums) -2; $i++) { 
Sfilter-$filter.$checkednums[$i].","; 


$filter-$filter.$checkednums [count ($checkednums) -2] .") "; 
$sql-"update ".$TableEb product." set featured-1 where id in 
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(".$filter; 
Squery-$db-»query ($sql); 
} 
if($status=="unfeatured") T 
Scheckednums-array (); 
$checkednums-explode('.',$ids); 
$filter-""; 
for($i-0;$i«count ($checkednums) -2; $i++) { 
$filter=$filter.$checkednums [$i].","; 
} 
$filter=$filter.s$checkednums [count ($checkednums) -2] .") "; 
$sql-"update ".$TableEb product." set featured-2 where id in 
(".$filter; 
$query-$db-»query ($sql); 
) 


// 转 移 产品 
if($status=="change product") 
t 
$checkednums-array(); 
s-explode('.',$ids); 


for($i-0;$i«count ($checkednums) -2; $i++) 
t 
$filter-$filter.$checkednums[$i].","; 
) 
$filter-$filter.$checkednums [count ($checkednums) -2] .") "; 
$sql-"update ".$TableEb product." Set 
eb product category id-".$change product category id." where id in 
(".$filter; 
$query-$db-»query ($sql); 
) 
$page-$ POST['page']; 
if (empty ($page) ) 
{$page=1; } 
else { 
if ($page<1){ $page-1;] 
} 
$b=false; 
$filter-""; 
$eb product category id-$ POST['eb product category id']; 
$fvalue-$eb product category id; 
if(!empty ($fvalue)) { 
if ($b) 
$filter.-" and"; 
$filter.-" (".$TableEb product.".eb product category id - 
SSEvalue- Or 
CONCAT(',',".$TableEb product.".nodepath, ',') like '$,".$fvalue.",$') "; 
$b-true; 
H 
$product id-$ POST['product id']; 
$fvalue-$product id; 
if(!empty ($fvalue)) { 
if ($b) 
$filter.-" and"; 
$filter.-" product id like '$".$fvalue."$' "; 
$b-true; 
} 
$product name-$ POST['product name']; 
$fvalue-$product name; 
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if (!empty ($fvalue)) { 
if ($b) 
$filter.=" and"; 
$filter.=" product name like '$".$fvalue."$' "; 
$b-true; 
b 
$is verify-$ POST['is verify']; 
$fvalue-$is verify; 
if(!empty($fvalue)) 1 
if ($b) 
$filter.=" and"; 
$filter.-" is verify = ".$fvalue." "; 
$b-true; 
} 
$is recomend-$ POST['is recomend']; 
$fvalue-$is recomend; 
if(!empty ($fvalue)) 
t 
if ($b) 
$filter.=" and"; 
$filter.=" is recomend = ".$fvalue." "; 
$b=true; 
$ 
$featured-$ POST['featured']; 
$fvalue-$featured; 
if(!empty ($fvalue)) { 
if ($b) 
$filter.=" and"; 
$filter.-" featured = ".$fvalue." "; 
$b-true; 
) 
$is special-$ POST['is special']; 
$fvalue-$is special; 
if(!empty ($fvalue)) ( 
if ($b) 
$filter.-" and"; 
$filter.-" is special - ".$fvalue." "; 
$b-true; 
5 
$is hot-$ POST['is hot']; 
$fvalue-$is hot; 
if(!empty ($fvalue)) T 
if ($b) 
$filter.=" and"; 
$filter.-" is hot = ".$fvalue." "; 


$b-true; ) 
$fvalue-"has link table"; 
if(!empty($fvalue)) 1 
if ($b) 


$filter.=" and"; 
$filter.-" ".$TableEb product.".eb product category id = 
".$TableEb product category.".id  "; 
Sp-true; $ 
$sql="select 
".STableEb product.".* ,".$TableEb product category.".name as 
eb product category name from 
".STableEb product." ,".$TableEb product category." ^"; 
$sgll-"select count(*) as num from 
".$TableEb product." ,".$TableEb product category." "; 
if($b) ( 
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$sql.-" where ".$filter." order by ".$TableEb product. 
".id desclimit".(($page-1) *$pagenum) .", $pagenum"; 
$sgll.-" where ".$filter." order by ".$TableEb product.".id desc"; 


} 


else { 
$sql.=" order by ".$TableEb product.".id desc limit". 


(($page-1) *$pagenum) .", $5pagenum"; 
$sgll.-" order by ".$TableEb product.".id desc "; 
} 
$result-$db-»getAll ($sql); 
$row=$db->getRow ($sql1); 
$totalnum-$row['num']; 
$page num-ceil($totalnum/$pagenum); 


?> 


7.54 管理 产品 目录 
电子 商务 的 平台 中 ， 为 了 方便 前 台 管理 和 使 用 ， 需 要 对 产品 目录 进行 管理 ， 例 如 新 增 
类 别 、 删 除 类 别 和 修改 类 别 等 ， 下 面 通过 一 段 代码 进行 讲解 ， 其 代码 (eb_product_ 


categoryadd.php) 如 下 : 


m 


«?phpphp 
// 新 增 数据 类 别 
$status-$ POST['status']; 
if($status--"add") ( 
Sindate-date('Y-n-j H:i:s'); 
$name-$ POST['name'];//F:H 4 
$sql-"select max(sortid) as sortid from 
where pid-0"; 
$rowsortid-$db-»getRow ($sql); 
$sortid- (int)$rowsortid['sortid']-41; 
$is leaf - "1"; 
$file name - $ FILES["file"]['name']; 


".$TableEb product category." 


$picture-substr($file name, strrpos ($file name,'.'),strlen($file name 


)-strrpos ($file name,'.')); 
if(!empty ($picture)) 
$picture-getRandomNum().$picture; 
$sql-"insert into 


".$TableEb product category."(link method,is leaf,id,name,pid,url,picture, 
sortid,is show)values(".$1ink method.",".$is leaf.",".$id.",'".$name."', 
Dl i x"tSpicburo." '," ISsortid."". SS Show: Ne 
$query-$db-»query ($591) ; 
$sgl-"select max(id) as id from 
$rowMax-$db-»getRow ($sql); 
$nodepath-"0,".$id; 
$sql-"update ".$TableEb product category." set nodepath-'".$nodepath."' 
where id-".$id; 
Squery-$db-»query ($591) ; 


".$TableEb product category; 


if($status--"addSub") 


t 
".$TableEb product category." 


$sql-"select max(sortid) as sortid from 
where pid-".$pid; 
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$rowsortid-$db-»getRow ($sql); 
$sortid-(int)$rowsortid['sortid']41; 
$is leaf - "1"; 

$file name = $ FILES["file"]['name']; 


$picture-substr($file name,strrpos($file name,'.'),strlen($file name 
)-strrpos($file name,'.')); 


if(l!empty ($picture)) 
$picture-getRandomNum().$picture; 
$sqgl-"insert into 


".$TableEb product category." 

(link method,is leaf,id,name,pid,url,picture,sortid,is show)values 

(NS Ixnkmethod:",". $33 leaf:" nm Hid '"".Snamoe."'" opid: mm Spp amt 
mt "5ssoptid:" "2sds5showsm)"r 


id-".$pid; 


id-".$pid; 


$query-$db-»query ($sq1); 
update parent category is leaf-2 
$sgl-"update ".$TableEb product category." set is leaf-2 where 


$db-»query ($sql); 

$sql-"select max(id) as id from ".$TableEb product category; 
$rowMax-$db-»getRow ($sql); 

$sql-"select * from ".$TableEb product category." Where 


S$rowParent-$db-»getRow ($sql); 
$nodepath-$rowParent ['nodepath'].",".$id; 
$sgl-"update ".$TableEb product category." Set 


nodepath-'".$nodepath."' where id-".$id; 


) 


$query-$db-»query ($sq1) ; 


if (!empty ($file name)) ( 


$FileName=$UploadPath."upload/eb product category/".$picture; 
$file - $ FILES['file']['tmp name']; 


if (copy($file,$FileName)) 


unlink ($file); 


| 2091950, % —— 

今天 我 和 同事 C 完成 了 后 台 模块 的 编码 工作 。 在 此 项 目 中 ， 我 深刻 意识 到 后 台 的 管理 
主要 是 管理 商品 和 产品 目录 ， 当 然 电子 商务 平台 也 因 设计 人 员 而 异 ， 如 当今 流行 的 在 线 支 
付 方式 ， 在 本 系统 中 并 没有 讲解 ， 读 者 可 以 去 寻找 一 些 其 他 资料 。 


7.6 数据 备份 和 恢复 


PAE 


我 们 完成 了 全 部 的 编码 工作 ， 心 想 终于 可 以 放松 休息 一 下 了 。 可 是 上 午 突然 接 到 了 老 
总 电话 ， 说 客户 要 求 添加 一 个 数据 库 备份 和 恢复 的 功能 ， 无 奈 之 下 我 只 好 和 同事 C 加 班 完 


成 了 。 


P. | 
V 深入 体验 PHP 项 目 开发 。 — 


7.6.1 数据 库 备份 管理 


在 电子 商务 中 ， 数 据 显得 十 分 重要 ， 因 为 里 面 有 客户 信息 、 电 子 商 城 的 商品 信息 ， 销 
售 信息 等 ， 所 以 一 个 完整 的 电子 商城 系统 ， 一 定 会 有 数据 备份 ， 下 面 通过 一 段 代 码 进行 讲 
解 ， 其 代码 (backup php) 如 下 : 

<?php 

include ("mydb.php"); 


include ("config.php"); 
pr— 界面 


$msgs[]=" 服 务 器 备份 目录 为 backup"; 
$msgs[]=" 对 于 较 大 的 数据 表 ， 强 烈 建议 使 用 分 卷 备份 "; 
$msgs[]=" 只 有 选择 备份 到 服务 器 ， 才 能 使 用 分 卷 备份 功能 "; 
show msg ($msgs); 
p 
«meta http-equiv-"Content-Type" content-"text/html; charset-gb2312"» 
«form name-"forml" method="post" action-"backup.php"» 
«table style-"font-size:l2px;" width-"99$" border-"1" cellpadding-'0' 
cellspacing-'l'» 
«tr align="center" class-'header'»«td colspan="2"> 数 据 备份 </td></tr> 
«tr»«td colspan="2"> 备 份 方式 </td></tr> 
<tr><td><input type="radio" name-"bfzl" value="quanbubiao"> 备 份 全 部 数据 
</td><tq> 备 份 全 部 数据 表 中 的 数据 到 一 个 备份 文件 </td></tr> 
<tr><td><input type-"radio" name-"bfzl" value="danbiao"> 备 份 单 张 表 数 据 
<select name="tablename"><option value=""> 请 选择 </option> 
«?php 
$d-»query("show table status from $mysqldb"); 
while ($d-»nextrecord())( 
echo "«option 
value-'".$d-»f('Name')."'»".$d-»f('Name') ."«/option»";] 
?» 
</select></td><td> 备 份 选中 数据 表 中 的 数据 到 单独 的 备份 文件 </td></tFr> 
«tr»«td colspan="2"> 选 择 目标 位 置 </td></tr> 
<tr><td colspan="2"><input type="radio" name="weizhi" value="server" 
checked> 备 份 到 服务 器 </td></tr><tr class-"cells"»«td colspan-'2'» «input 
type="radio" name-"weizhi" value-"localpc"» 
备份 到 本 地 </td></tr> 
«tr»«td colspan-"2" align-'center'»«input type-"submit" name-"act" 
value-" 4 "»«/td»«/tr» 
«/table» 
«/form» 


主 程序 


if($ POST['weizhi']--"localpc"&&$ POST['fenjuan']--'yes') 
{$msgs[]=" 只 有 选择 备份 到 服务 器 ， 才 能 使 用 分 卷 备份 功 能 "; 

show msg($msgs); pageend();} 

if($ POST['fenjuan']--"yes"&&'$ POST['filesize']) 
($nsgs []=" 您 选择 了 分 卷 备份 功能 ， 但 未 填写 分 卷 文件 大 小 "7 

show msg($msgs); pageend();} 

if($ POST['weizhi']--"server"&&!writeable("./backup")) 
($msgs []=" 备 份 文件 存放 目录 ' - /backup ' 不 可 写 ， 请 修改 目录 属性 "7 
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show msg($msgs); pageend();) 
/* 


if(!Stables-$d-»query("show table status from $mysqldb")) 
{$msgs[]=" 读 数据 库 结 构 错误 "; show msg($msgs); pageend();) 
$sgl-""; 
while($d-»nextrecord($tables)) ( 
Stable-$d-»f ("Name"); 
$sql.-make header ($table); 
$d-»query("select * from $table"); 
$num fields-$d-»nf(); 
while ($d-»nextrecord()) 
($sql.-make record($table,$num fields);] } 
$filename=date ("Ymd",time())." all.sql"; 
if($ POST['weizhi']--"localpc") down file($sql,$filename); 
elseif($ POST['weizhi']--"server") 
(if(write file($sql,$filename)) 
$nsgs [] =" 全 部 数据 表 数 据 备份 完成 , 生成 备份 文件 ' . /backup/Sfilename'"; 
else $msgs[]=" 备 份 全 部 数据 表 失 败 "; 
show msg ($msgs); 
pageend () ; 


if(!$ POST['filesize']) deis [] =" 请 填写 备份 文件 分 卷 大 小 *; 
show msg ($msgs) ;pageend() ; 
BEIC 人 table status from $mysqldb") F 
($msgs [] =" 读 数据 库 结构 错误 "; show msg($msgs); pageend(); 
$sql=""; $p=1; 
$filename=date ("Ymd",time())." all"; 
while ($d-»nextrecord($tables)) ( 
$table-$d-»f ("Name") ; 
$sql.-make header ($table); 
$d-»query("select * from $table"); 
$num fields-$d-»nf(); 
while ($d-»nextrecord()) 
($sql.-make record($table,$num fields); 
if (strlen ($sql)>=$ POST['filesize']*1000)( 
$filename.=(" v".$p.".sql"); 
if (write file($sql,$filename)) 
$msgs[]=" 全 部 数据 表 - 卷 -" .$p."- 数 据 备份 完成 , 生成 备份 文件 
' ./backup/Sfilename'"; 
else $msgs[]-" f) X-".$ POST['tablename']."-Wk"; 
$ptt; 
$filename-date ("Ymd",time())." all"; 
$sgi-"";) JJ) 
if($sql!-"")($filename.-(" v".$p.".sql"); 
if(write file($sql,$filename)) 
$msgs[]=" 全 部 数据 表 - 卷 -".$p."- 数 据 备份 完成 , 生成 备份 文件 ' . /backup/$filename'";) 


show msg ($msgs); 
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{$msgs[]=" 请 选择 要 备份 的 数据 表 "; show msg($msgs); pageend();) 


IEUS POSTL"Fonman ,ll}lre== * 
$sql=make header($ POST['tablename']); 

$d->query ("select * from ".$ POST['tablename']); 

$num fields-$d-»nf(); 

while ($d-»nextrecord()) 

($sql.-make record($ POST['tablename'],$num fields);} 
$Sfilename-date ("Ymd",time())." ".$ POST['tablename'].".sql"; 
if($ POST['weizhi']--"localpc") down file($sql,$filename); 
elseif($ POST['weizhi']--"server") 

{tif (write file($sql,S$filename)) 
$msgs[]=" 表 -".$_POST['tablename']."- 数 据 备份 完成 , 生成 备份 文件 
' ./backup/$filename'"; 

else $msgs[]=" 备 份 表 -".$ POST['tablename'] ."- 失 败 "; 

show msg ($msgs); 

pageend(); | 


/*---------------- 分 卷 */else{/*-------------------------------------- */ 
if(!$ POST['filesize']) 
($msgs [] =" 请 填写 备份 文件 分 卷 大 小 "7 Show msg ($msgs) ;pageend () ; } 
$sql-make header ($ POST['tablename']); $p-1; 
$filename-date ("Ymd",time())." ".$ POST['tablename']; 
$d->query ("select * from ".$ POST['tablename']); 
$num fields-$d-»nf(); 
while ($d-»nextrecord()) ( 
$sql.-make record($ POST['tablename'],$num fields); 
if(strlen($sql)»-$ POST['filesize']*1000)( 
$filename.-(" v".$p.".sqgl"); 
if(write file($sql,$filename)) 
$msgs[]-"X-".$ POST['tablename'] ."- 卷 -".$p."- 数 据 备份 完成 , 生成 备份 文件 
' ./backup/Sfilename'"; 
else $msgs[]=" 备 份 表 -".$ POST['tablename'] ."- 失 败 "; 
$p++; 
$filename=date ("Ymd",time())." ".$ POST['tablename']; 
$sgl-"";] } 
if($sql!="") {$filename.=(" v".$p.".sql"); 
if (write file($sql,$filename)) 
S$msgs []=" 表 -".$ POST['tablename'] ."- 卷 -".Sp."- 数 据 备份 完成 , 生成 备份 文件 
'./backup/$filename'";] 
show msg($msgs); 


function write file($sql,$filename) ( 
$re-true; 
if(!0$fp-fopen("./backup/".$filename,"w-")) ($re-false; echo "failed to 
open target file";} 
if(!8fwrite($fp,$sql)) ($re-false; echo "failed to write file";) 
if(!8fclose($fp)) ($re-false; echo "failed to close target file";] 
return $re; } 
function down file($sql,S$filename) ( 
ob end clean(); 
header ("Content-Encoding: none"); 
header("Content-Type: ".(strpos($ SERVER['HTTP USER AGENT'], 'MSIE') ? 
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'application/octetstream' : 'application/octet-stream')); 
header ("Content-Disposition: 
".(strpos($ SERVER['HTTP USER AGENT'], 'MSIE') ? 'inline; ' : 'attachment; 


')."filename-".$filename); 
header("Content-Length: ".strlen($sq1)); 
header("Pragma: no-cache"); 
header("Expires: 0"); 
echo $sql; 
$e-ob get contents(); 
ob end clean(); 
H 
function writeable ($dir) ( 
if(!is dir($Sdir)) { 
@mkdir ($dir, 0777); } 
if(is dir($dir)) 
t 
if ($fp = G(fopen("$dir/test.test", 'w')) " 
@fclose ($fp); 
QGunlink("$dir/test.test"); 
$writeable - 1; 
H else ( 
$writeable = 0; 
) ) 
return $writeable; 
} 
function make header ($table) 
(global $d; 
$sql-"DROP TABLE IF EXISTS ".$table."Wn"; 
$d->query ("show create table ".$table); 
$d-»nextrecord(); 
$tmp-preg replace("/WMn/","",$d-»f("Create Table")); 
$sql.=$tmp."\n"; 
return $sql; } 
function make record ($table, $num fields) 
{global $d; 
$comma=""; 
INSERT INTO ".$table." VALUES ("; 
0; $i < $num fields; $i++) 
{$sql .= ($comma."'".mysql escape string($d-»record[$i])."'"); $comma = 
AD 
$sql .= ")Wn"; 
return $sql; } 
function show msg($msgs) ( 
$title=" 提 示 : "; 
echo "<table width-'100$' border='1' cellpadding-'0' cellspacing-'1'»"; 
echo "«tr»«td»".$title."«/td»«/tr»"; 
echo "«tr»«td»«br»«ul»"; 
while (list($k,$v)-each($msgs))( 
echo "cIl1»" $v."c/115"7] 
echo "«/ul»«/td»«/tr»«/table»";] 
function pageend()í 
exit();) 
?» 


7.6.2 数据库 恢复 管理 
在 电子 商城 中 ， 当 数据 库 备份 后 ， 如 果 服 务 器 数据 库 的 数据 错误 ， 可 以 将 备份 文件 恢 
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复 到 服务 器 中 ， 下 面 通过 一 段 代码 实现 这 个 功能 ， 其 代码 (restore.php) 如 下 : 


<?php 
include ("mydb.php"); 
include ("config.php"); 
Jes RUE 
*/if(!$ POST['"act"]&&!$ SESSION['data $1611) (/ X433 d kdo exon 
I 
«meta http-equiv-"Content-Type" content-"text/html; charset-gb2312"» 
«form action-"" method-"post" enctype-"multipart/form-data" 
name-"restore.php"» 
<table width-"91$" style-"font-size:12px;" border-"0" cellpadding-"0" 
cellspacing-"1"» 
«tr align="center" class-"header"» 
«td colspan-"2" align-"center"»Restore«/td» 
Str 
<tr><td width-"33$"»«input type="radio" name-"restorefrom" value-"server" 
checked» 
Restore from server«/td»«td width-"67$"»«select name-"serverfile"» 
<option value-""»-Select-«/option» 
«?php 
Shandle-opendir('./backup'); 
while ($file = readdir(S$handle)) ( 
if(eregi("^[0-9](8,8) ([0-9a-z ]+) (N.sql1)$",$file)) echo "<option 
value-'$file'»$file«/option»";] 
closedir ($handle); 
?» 
</select> </td></tr> 
<tr><td><input type="radio" name="restorefrom" value="localpc"> 
Restore from local </td> 
<td><input type="hidden" name="MAX FILE SIZE" value="1500000"><input 
type="file" 
name="myfile"></td></tr> 
<tr><td colspan="2" align="center"> <input type="submit" name="act" 
value="submit"></td> 
</tr></table></form> 
«9?php/ * * kooeekdcoeekieeeeieeeeeoe HE AE 
Xp dee deedekeeeedekekeeeeeeeee e 了/ 
JOROeeeieeieeeeeieeeeeeoeeek ERIT * /if(s POST['act']==" 恢 复 
my (/****kkk xe ede 
/太太 大 去 克 太太 大 友 太 太太 太太 大 服 务 器 恢复 
*/if($ POST['restorefrom']--"server")(/**************/ 
if(!$ POST['serverfile']) 
{$msgs[]=" 您 选择 从 服务 器 文件 恢复 备份 ， 但 没有 指定 备份 文件 "; 
show msg($msgs); pageend(); ) 
if(!eregi(" v[0-9]«",$ POST['serverfile'])) 
($filename-"./backup/".$ POST['serverfile']; 
if(import($filename)) $msgs[]-"Restore ".$ POST['serverfile']." import 
successfully"; 
else $msgs[]-"Restore ".$ POST['serverfile']." import failing"; 
show msg($msgs); pageend(); 
)else 1 
$filename-"./backup/".$ POST['serverfile']; 
if (import ($filename)) $msgs[]-"Restore".$ POST['serverfile']." Import 
successfully"; 
else ($msgs[]-"Restore".$ POST['serverfile']." import 
failing";show msg ($msgs);pageend();) 
$voltmp-explode(" v",$ POST['serverfile']); 
$volname-$voltmp[0]; 
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$volnum-explode (".sq",$voltmp[1]); 
$volnum-intval ($volnum[0])-41; 
$tmpfile-$volname." v".$volnum.".sqgl"; 
if (file exists("./backup/".$tmpfile)) 
$msgs []=" 程 序 将 在 3 秒 钟 后 自动 开始 导入 此 分 卷 备份 的 下 一 a: 文件 ".$tmpfile."， 请 勿 手 
动 中 止 程序 的 运行 ， 以 免 数 据 库 结构 受 损 "; 
$ SESSION['data file']=$tmpfile; 
show msg ($msgs); 
sleep (3); 
echo "<script language-'javascript'»"; 
echo "location-'restore.php';"; 
echo "</script>"; ) 
else( 
$msgs[]=" 此 分 卷 备份 全 部 导入 成 功 "; 
show msg ($msgs); 
} 
/太太 太太 太太 太太 太太 太太 二 服务 器 恢复 结束 
XA A 
/太太 太太 太太 友 太太 友 太 大友 太太 太太 本 地 恢复 
*/if($ POST['restorefrom']--"localpc") (/*************x*/ 
switch ($ FILES['myfile']['error']) { 
case 1: 
case 2: 
$msgs[]=" 您 上 传 的 文件 大 于 服务 器 限定 值 ， 上 传 未 成 功 "; 
break; 
case 3: 
$nsgs []=" 未 能 从 本 地 完整 上 传 备份 文件 "; 
break; 
case 4: 
$msgs []=" 从 本 地 上 传 备份 文件 失败 "7 
break; 
case 0: 
break; } 
if($msgs) (show msg ($msgs) ;pageend () ; ) 
$fname-date ("Ymd",time()).".sql"; 
if (is uploaded file($ FILES['myfile']['tmp name'])) ( 
copy($ FILES['myfile']['tmp name'], "./backup/".$fname);]) 
if (file exists("./backup/".$fname)) ( 
$msgs[]=" 本 地 备份 文件 上 传 成 功 "; 
if(import("./backup/".$fname)) {$msgs[]=" 本 地 备份 文件 成 功 导入 数据 库 "; 
unlink("./backup/".$fname);] 
else $msgs[]=" 本 地 备份 文件 导入 数据 库 失败 "; } 
else ($msgs[]=" 从 本 地 上 传 备份 文件 失败 ") ; 
show msg ($msgs); 
VLLLLE 3:00 9-17 p RERLLNEAULLLLLLLLRLLLLLLLLLLRLLLLLLLLLLLL LL LLLLLLLLLLLLLLMA 
JROOIOKERCIO Geek Rekekeelocioeieeoieeex JEJ ER JR Ok eR ROROOROK JO OK CR JO OR ORO RK / 
JACO AOI ok ok Rokekeelekcekeeie i| e 4) 20 [1] TK d CR RC OK RORORORORORO OK ORO OK eK ORO Re / 
if(!$ POST['act']&&$ SESSION['data file']) ( 
$filename-"./backup/".$ SESSION['data file']; 
if (import ($filename)) $msgs[]=" 备 份 文件 ".$_SESSION['data file'] ." 成 功 导 
入 数据 库 "; 
else {$msgs[] TEA .$ SESSION['data file'] ." 导 入 失败 "; 
Show msg ($msgs) ;pageend () ; 
$voltmp-explode(" v",$ Sen data - file']); 
$volname- $voltmp[0]; 2 
$volnum-explode (".sq",$voltmp[1]); 
$volnum-intval ($volnum[0])-41; 
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$tmpfile-$volname." v".$volnum.".sqgl"; 
if (file exists("./backup/".$tmpfile)) T 
$msgs[]=" 程 序 将 在 3 秒 钟 后 自动 开始 导入 此 分 卷 备份 的 下 一 部 份 : 文件 ". Stmpfile.", 请 
勿 手动 中 止 程序 的 运行 ， 以 免 数 据 库 结构 受 损 "; 
$ SESSION['data file']=$tmpfile; 
show msg ($msgs) ; 
sleep (3); 
echo "<script language-'javascript'»"; 
echo "location-'restore.php';"; 
echo "</script>"; 
}else{ 
$msgs []=" 此 分 卷 备份 全 部 导入 成 功 "; 
unset($ SESSION['data file']); 
show msg ($msgs); 
) 
H 
Je de] 4 4) 16 eL) c d Lt HDROCOOCOOOOOOOOOOOOOOOOOOROOOROOOR E / 
function import ($fname) 
(global $d; 
$sqls-file($fname); 
foreach($sqls as $sql) ( 
str replace ("\r","", $sql); 
str replace ("\n","", $sql); 
if(!$d-»query(trim($sq1))) return false; ) 
return true; } 
function show msg($msgs) ( 
$title=" 提 示 : "; 
echo "<table width-'100$' border='1' cellpadding-'0' cellspacing-'1'»"; 
echo "«tr»«td»".$title."«/td»«/tr»"; 
echo "«tr»«td»«br»«ul»"; 
while (list($k,$v)-each($msgs))( 
echo reli Se eli 
echo "</ul></td></tr></table>"; 
} 
function pageend(){ 
exit();) 
?» 


今天 我 和 同事 C 终于 完成 了 数据 库 的 备份 和 恢复 工作 。 我 深 知 数据 是 一 个 网 站 的 核心 
尤其 是 电子 商务 的 核心 ， 用 户 需 要 随时 备份 好 数据 ， 以 免 丢 失 。 目 前 ， 互 联网 、 黑 客 和 恶 
意 攻 击 的 人 较 多 ， 再 完善 的 系统 ， 也 可 能 有 漏洞 ， 所 以 数据 库 备 份 不 能 忽视 。 
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我 们 做 这 个 项 目 ， 可 以 说 是 费 了 九 牛 二 虎 之 力 ， 今 天 终于 看 到 了 胜利 的 曙光 ， 最 后 的 
项 目测 试 工作 由 我 来 完成 。 在 此 我 将 工程 命名 为 “07shop”。 
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7.7.1 系统 运行 预览 


现在 开始 运行 测试 ， 在 浏览 器 中 输入 运行 地 址 ， 整 个 项 目 进入 运行 状态 ， 运 行 后 的 主 
界面 效果 如 图 7-8 所 示 。 
wad A-D- 29- mmv- 220- TRO- 8- 
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图 7-8 界面 运行 的 效果 
7.7.2 验收 


酷热 的 夏天 来 了 ， 我 和 小 组 成 员 ， 经 过 几 天 的 测试 ， 将 项 目 交 给 经 理 进行 审核 ， 经 理 
认真 审核 、 签 字 ， 并 同意 投入 使 用 。 在 后 期 维护 上 ， 我 们 也 安排 了 分 工 ， 同 事 B 将 负责 整 
个 项 目的 运行 。 如 出 现 什么 问题 ， 将 与 我 和 其 他 成 员 沟通 后 及 时 地 解决 。 


7.7.3 ”总结 


这 个 项 目 让 我 学 到 了 许多 东西 ， 在 项 目的 过 程 中 ， 我 也 遇 到 了 很 多 困难 ， 虽 然 这 个 系 
统 满足 了 经 理 的 需求 ， 但 是 还 有 很 多 可 以 提高 的 地 方 。 电 子 商 务 在 过 去 的 十 年 发 展 迅 速 ， 
在 当今 电子 商务 十 分 泛滥 的 时 代 ， 如 何 脱颖而出 才 是 各 大 站 长 们 首要 考虑 的 问题 。 作 为 初 
入 道 的 程序 员 也 需要 关注 电子 商务 站 点 的 发 展 方向 。 根 据 这 个 项 目 ， 总 结 出 如 下 3 点 经 验 。 

1) 平台 服务 对 象 

目前 ， 电 子 商 务 按 行业 性 质 可 分 为 B2B、B2C、C2C、B2M 和 M2C 等 类 型 ， 在 种 类 繁多 
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的 模型 中 寻找 最 具 人 气 的 模型 。 当 今 最 流行 的 无 非 是 前 三 种 ， 都 是 采用 B/S 模式 结构 。 开 发 
语言 有 PHP、JAVA 等 ， 但 利用 JAVA 平台 开发 占 多 数 。 因 为 不 管 是 结构 ， 还 是 在 开发 语言 
都 要 大 众 化 ， 为 以 后 建立 更 大 的 服务 平台 做 准备 。 

2) 平台 价值 体现 

平台 价值 不 只 是 平台 交易 中 产生 利益 ， 作 为 设计 开发 平台 的 设计 者 来 说 。 更 要 为 平台 
扩展 ， 与 其 他 系统 的 对 接 方面 预 留 接 口 。 最 基本 的 接口 是 与 银联 对 接 ， 划 拨 每 笔 交易 款项 。 
为 平台 预 留 让 外 部 可 以 访问 的 接口 ， 方 便 日 后 与 其 他 优秀 系统 进行 数据 共享 和 数据 交换 。 

3) 安全 性 和 稳定 性 
电子 商务 的 安全 性 ， 在 平台 设计 之 初 是 必须 考虑 的 问题 。 在 整个 交易 过 程 如 何 保证 数 
据 的 几 大 特性 ? 如 : 信息 有 效 性 、 信 息 机 密 性 、 信 息 完整 性 、 信 息 可 靠 性 、 不 可 抵赖 性 和 
可 鉴别 性 等 。 掌 握 数 据 加 密 技术 是 做 电子 商务 平台 研发 的 必修 课 ， 数 据 加 密 的 技术 分 为 两 
类 ， 即 对 称 加 密 ( 私 人 密 钥 加 密 )， 对 称 加 密 以 数据 加 密 标准 (DES，Data Encryption Standard) 
算法 为 典型 代表 。 非 对 称 加 密 ( 公 开 密 钥 加 密 ) 通 常 以 RSA(Rivest Shamir Adleman) 算 法 为 代 
表 。 对 称 加 密 的 加 密 密 钥 和 解密 密 钥 相同 ， 而 非 对 称 加 密 的 加 密 密 钥 和 解密 密 钥 不 同 ， 加 
密 密 钥 可 以 公开 而 解密 密 钥 需 要 保密 。 
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斗 地 主 是 一 款 深 受 中 国 广大 网 民 喜 欢 的 游戏 ， 不 论 大 

人 小 孩 都 喜欢 这 款 游戏 ,在 互联 网 飞速 发 展 的 今天 ， 斗 地 

7 主 游戏 也 逐渐 走 进 网 络 游戏 的 领域 , 让 人 们 可 以 在 互联 网 

体验 一 把 斗 地 主 的 乐趣 ， 斗 地 主 游戏 带 给 人 们 无 穷 无 尽 的 
乐趣 。 

在 本 章 的 内 容 中 ， 将 详细 讲解 开心 斗 地 主 的 构建 ， 虽 

在 让 读者 牢固 掌握 网 页 游戏 的 建立 、 维 护 以 及 前 台 应 用 程 

序 的 开发 ， 为 以 后 深入 地 学 习 打 下 坚实 的 基础 。 
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8.4 游戏 ， 让 我 快乐 


我 小 的 时 候 就 喜欢 玩 游戏 ， 买 着 学 习 机 连接 着 电视 打 魂 斗 罗 。 念 高 中 时 ， 还 偷偷 去 镇 
上 的 游戏 厅 ， 尝 尽 了 游戏 的 乐趣 。 念 大 学 了 ， 玩 游戏 就 更 不 用 说 了 ， 所 有 究 室 都 玩 游戏 。 
去 年 ， 开 心 农场 极 大 影响 了 我 们 ， 可 是 身 为 程序 员 的 我 们 ， 有 没有 想 过 自己 开发 一 款 游戏 ， 
让 别人 也 为 之 着 迷 ? 


8.1.1 项 目 来 源 
四 2009 征 07 月 76, 而 
夏天 ， 办 公 室 死 气 沉沉 的 ， 项 目 组 又 没有 什么 大 的 项 目 ， 所 以 大 多 时 间 很 闲 ， 又 因 项 


目 组 进来 了 两 个 人 新 人 ， 正 处 于 考核 期 ， 经 理 就 找 我 ， 琢 磨 着 开发 个 棋牌 游戏 ， 一 来 让 他 
们 熟悉 环境 ， 二 来 游戏 也 可 供 程序 组 解 解 间 。 我 得 到 指示 后 ， 立 即 回 到 项 目 组 开始 准备 。 


8.1.2 ”组建 团队 
(2005018189, —— 

项 目 不 算 大 ， 公 司 能 让 我 用 的 人 也 不 多 ， 我 将 能 用 的 人 组 建 了 一 个 团队 ， 团 队 成 员 
如 下 。 

同事 A: 


他 来 自 新 疆 ， 平 时 很 少 说 话 ， 来 公司 几 天 了 ， 他 除了 埋头 苦 干 外 ， 就 是 努力 地 编写 程 
序 ， 由 于 他 没有 做 过 什么 项 目 ， 就 只 能 让 它 为 这 个 项 目 做 简单 的 工作 。 

任务 : 负责 项 目 规划 ， 扎 写 系统 设计 规划 书 。 

同事 B: 

他 来 自 万 州 ， 他 除了 喜欢 计算 外 ， 还 喜欢 雕刻 ， 从 事 软件 已 经 半年 了 ， 对 需求 分 析 和 
数据 库 设 计 比 较 有 天 赋 。 

任务 : 负责 需求 分 析 和 数据 库 设计 。 

同事 C: 

电视 里 面 有 个 王宝强 ， 是 个 演 喜 剧 的 演员 ， 他 们 的 名 字 只 差 一 个 字 ， 但 是 都 有 喜剧 天 
R ERARA GAHE, BRAA. 
任务 : 负责 用 户 管理 和 游戏 角色 设计 。 

我 : 

目前 是 公司 项 目 组 组 长 ，IT 界 一 只 待 飞 的 小 鸟 。 

任务 : 负责 系统 整体 框架 设计 ， 并 协调 项 目 中 各 个 模块 的 进展 。 

具体 职能 结构 如 图 8-1 所 示 。 

整个 项 目的 具体 操作 流程 是 : 项目 规划 一 数据 库 设 计 一 框架 设计 一 用 户 管理 、 游 戏 设 
计 、 角 色 设 计 。 
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同事 A 同事 B 
所 与 系 统 设计 规划 书 数据 库 设计 和 需求 分 析 


同事 C 
用 户 管理 和 角色 设计 


我 
整体 框架 设计 
协调 整个 项 目 


图 8-1 职能 结构 图 


8.4.3 小 会 议 


在 制作 项 目前 ， 我 将 项 目 组 的 成 员 组 织 在 一 起 ， 对 整个 项 目 进行 了 介绍 和 设想 ， 也 对 
要 达到 的 目标 、 项 目的 大 小 和 内 容 进行 了 讲解 。 最 后 对 整个 项 目的 工作 进行 了 明确 的 分 工 ， 
本 项 目 包括 后 台数 据 库 和 游戏 设计 两 大 功能 模块 ， 在 制作 的 时 候 ， 要 尽量 用 较 少 的 代码 完 
成 整个 项 目 。 

大 家 一 致 提议 同事 A 尽快 作出 规划 书 ， 后 续 工 作 将 以 规划 书 为 基础 进行 扩展 。 


8.2 系统 概述 和 总 体 设计 


今天 同事 A 做 出 了 项 目 规划 书 ， 整 个 规划 书 分 为 以 下 两 个 部 分 : 
OQ Aka 
口 、 系 统 运行 流程 

8.2.1 系统 需求 分 析 


所 谓 网 页 游戏 ， 就 是 用 户 打开 浏览 器 ， 在 浏览 器 输入 网 址 就 能 玩 的 游戏 ， 开 心 斗 地 主 
的 具体 功能 如 下 。 
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1. 用 户 管理 

用 户 管理 有 用 户 注 册 和 用 户 管理 ， 因 为 每 一 个 进来 的 人 都 需要 有 自己 的 角色 ， 否 则 系 
统 将 无 法 判断 谁 输 谁 赢 。 

2. 房间 设置 

这 是 多 人 玩 的 游戏 ， 一 个 房间 只 能 有 固定 的 人 玩 ， 当 一 个 房间 满 后 ， 需 要 在 另外 的 房 


间 玩 斗 地 主 ， 房 间 设置 十 分 重要 。 

3. 随机 发 牌 

在 开始 游戏 的 时 候 ， 系 统 将 会 为 参加 游戏 的 每 一 个 人 重新 发 牌 。 

4. 出 牌 规则 

在 设计 游戏 时 ， 需 要 重点 考虑 出 牌 的 规则 ， 如 别人 出 了 “2”， 什 么 牌 都 可 以 大 过 它 ， 
可 以 出 牌 。 

根据 需求 分 析 中 总 结 的 用 户 需求 设计 系统 的 体系 结构 ， 每 一 个 功能 模块 都 需要 针对 不 
同 的 表 完 成 相同 的 数据 库 操作 。 


8.22 ”系统 运行 流程 


开心 斗 地 主 游戏 实际 上 对 数据 库 的 要 求 比较 简单 ， 比 前 面 的 程序 也 简单 了 许多 ， 出 牌 
规则 是 这 个 游戏 的 难点 。 当 用 户 输入 网 址 进入 网 页 并 进入 到 房间 后 ， 效 果 如 图 8-2 所 示 。 
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8.3 数据 库 设计 
| 2009 年 7 月 22 日 ， 阳 光明 如 


本 项 目 系统 的 开发 主要 包括 后 人 台数 据 库 的 建立 、 维 护 以 及 前 端 应 用 程序 的 开发 两 个 方 
。 数 据 库 设计 是 开心 斗 地 主 游戏 开发 的 一 个 重要 组 成 部 分 。 此 阶段 的 任务 是 由 同事 B 来 
完成 的 ， 他 是 数据 库 设计 的 老手 了 ， 也 深 知 数据 库 在 动态 网 站 系统 中 的 重要 性 ， 所 以 秉承 
科学 、 合 理 、 高 效 的 原则 设计 出 了 系统 的 数据 库 。 


8.3.1 数据 库 结构 的 设计 


数据 库 设 计 由 同事 B 来 完成 。 由 需求 分 析 的 规划 可 知 整个 项 目 对 象 有 两 种 信息 ， 所 以 
对 应 的 数据 库 也 需要 包含 这 两 种 信息 ， 从 而 系统 需要 包含 两 个 数据 库 表 ， 分 别 是 : 

O user ddz: 用 户 信 息 表 

O room ddz: 房间 信息 表 

同事 B 给 出 了 具体 数据 库 表 的 书面 文件 如 下 。 

(1) 房间 信息 表 (room_ddz)， 用 来 保存 整个 系统 的 房间 信息 ， 表 结构 如 表 8-1 所 示 。 


表 8-1 房间 信息 表 


FR am 整理 属性 “Null RU LI 
D mediumint(9) m auto_increment 
name varchar(25) wutf8 general ci Ej 
playert name  varchar(25) utfà general. ci Ej 
Player2 name  varchar(25) wtf general ci Li 
lord enumC', playerT, player2) utf8 general ci Ej 
flag enum(, ‘playerT, ‘player2)  utf8 general ci Ei 
Plyert p  varchar(100) wiffà general ci z 
player2 p  varchar(100) utB_general_ ci * 
lord p. varchar(20) wtf general ci Ej 
Player! time — int(12) moo 
player2 time — int(12) m 0 
system time — int(12) moo 
playert show  varchar(100) utf8 general. ci Ej 
player2 show  varchar(100) utf8 general, ci Ei 
(2) 用 户 信息 表 (user ddz)， 用 来 保存 整个 系统 的 用 户 信息 ， 表 结构 如 表 8-2 所 示 。 
表 8-2 ”用户 信息 表 
字段 类 型 -m Et nu RA ki 
ID mediumint(9) EJ auto increment 
name varchar(25) ^ utf8 general ci Ej 
password varchar(32) ^ utf8 general ci EJ 
time int(12) 8 0 
face int(2) Ta 
win int(9) z 0 
lost int(9) mo 
run int(9) 8 0 
score int(9) 否 0 


s | 
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8.32 数据库 配置 信息 


完成 数据 库 设计 的 时 候 ， 用 户 需 要 编写 一 个 配置 信息 ， 供 程序 员 调 用 ， 下 面 通 过 一 段 
代码 进行 讲解 ， 其 代码 (config.inc.php) 如 下 : 

«?php 

if(!mysql connect ('localhost','root','1234'))// 数据 库 信息 

die (数据 连接 失败 ! ) ; 


mysql_ select db('youxi');// 选 择 数据 库 
?» 


8.3.3 ”常用 的 数据 库 程序 


在 8.3.2 节 中 ， 讲 解 了 数据 库 的 配置 信息 ， 在 这 个 程序 中 ， 除 了 数据 库 程序 ， 还 有 许多 
程序 都 是 需要 用 到 的 ， 下 面 是 具体 实现 代码 (dbconnectphp): 

<?php 

include "./config.inc.php";// 连 接 数据 库 

// 新 建 一 个 数组 


ob start(); 
$p = 


array('1','2','3','4', '5' , !6', '7','8', '9','10','11', '12', 13! , 'F1' ,'F2', 
'F3','F4', 'F5', 'F6', 'F7' , 'F8', 'F9', 'F10', 'F11','F12', 

'F13','T1','T2', 'T3' , 'T4' , 'T5' , ' T6' ,' T7' , ' T8' , ' T9' ,' T10' ,'T11' , 'T12', ' T1 
3','H1','H2','H3', 'H4' , 'H5', 'H6' , 'H7', 'H8', 'H9', 'H10', 'H11', ' H12', 'H13', 
'JOKE1','JOKE2'); 

// 新 建 一 个 数组 

$pv = array( 

13' => 3, 'F3' => 3, 'T3' => 3, 'H3' => 3, '4' => 4, 'F4' => 4, 'T4' — 4, 
'H4' => 4, '5' => 5, 'F5' => 5, 'T5' => 5, 'H5' => 5, 

16' => 6, 'F6' => 6, 'T6' => 6, 'H6' => 6, '7' => 7, "ET! => 7, 'T7' => 1, 
'H7' => 7, '8' => 8, 'F8' => 8, 'T8' => 8, 'H8' => 8, 

'9'! => 9, 'F9' => 9, 'T9' => 9, 'H9' => 9, '10' => 10, 'F10' => 10, 'T10' 
=> 10, 'H10' — 10, '11' => 11, 'Fll' => 11, 

vip —» bp il —- DITE ANE epo RED — a2 E UTT28 5212, H1 0 
12, '13' — 13, 'Fl3' — 13, 'T13' — 13, 'H13' — 13, '1' => 14, 'Fl' — 
14, 'Tl' => 14, 'Hl' => 14, '2' => 15, 'F2' — 15, 'T2' => 15, 'H2' => 15, 
'JOKEl' => 16, 

'JOKE2' => 17); 
function renew($pai)( global $pv;// 更 新 信息 

$e pai = explode(",", $pai); 
for($i = 0;$i < sizeof($e pai) - 2;$i ++) 
for($j = $i + 1;$j < sizeof($e pai) - 1;$j ++) 


if(Spv[Se pai[$i]] > $pv[$e pai[$j]]) 


$temp = $e pai[$i]; 
$e pai[$i] = $e pail$jl; 
$e pai[$j] = $temp; 
Ji l 
for($pai = '', $i = 0;$i < sizeof($e pai) - 1;$i ++) 
$pai .= $e pai[Si].","; 


人 人 - 
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return $pai; 
} 
function message ($message, $url) 
{// 消 息 处 理 
setcookie (message, $message); 
header ("location:".$url); 


exit; 
) 
function get p() 
t 


global $p; 
$p temp = $p; 
$p new = array(); 
for($i = 0;$i < 37;$i ++) 
t 
$p new[$i] = $p temp[rand(0, sizeof($p temp) - 1)]; 
for($p temp temp = array(), $j = 0, $k = 0;$j < sizeof ($p temp);$j ++) 


if($p temp[$j] != $p new[$i]) 
$p temp temp[$k ++] = $p temp[$j]; 


$p temp = array (); 

$p temp = $p temp temp; } 
return $p new; } 
mysql query ("SET NAMES 'UTF8'"); 
$player name = $ COOKIE[player name]; 
$ori time = time(); 


o 


数据 库 是 一 个 系统 的 核心 ， 管 理 着 用 户 信息 和 游戏 信息 。 由 于 同事 B 开发 过 很 多 个 项 
目 ， 所 以 很 快 完成 了 数据 库 的 建立 和 搭建 工作 。 在 建立 和 搭建 数据 库 的 时 候 ， 初 学 者 要 特 
别 注意 规范 数据 库 的 结构 和 数据 库 的 字段 信息 。 数 据 库 的 配置 信息 程序 和 常用 的 数据 库 程 
序 ， 用 户 一 定 要 将 其 独立 ， 这 种 方法 可 以 尽量 减 短程 序 ， 加 快 整个 程序 的 运行 。 
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在 同事 B 完成 数据 库 设计 工作 之 后 ， 整 个 项 目 马上 进入 了 具体 设计 和 编码 阶段 。 首 先 
实现 用 户 管理 模块 功能 ， 此 模块 功能 是 由 同事 C 实现 ， 他 在 参考 项 目 规划 书 和 设计 好 的 数 
据 库 后 ， 一 个 成 熟 的 方案 已 经 在 他 脑海 中 形成 了 。 


8.4.1 登录 系统 


当 用 户 拥有 一 个 账号 的 时 候 ， 可 以 凭借 自己 的 用 户 名 和 密码 登录 系统 ， 登 录 页 如 图 8-3 
Bras. 
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图 8-3 系统 登录 首页 


下 面 通过 一 段 代 码 进行 讲解 ， 其 代码 (index.php) 如 下 : 
«?php 
include "./dbconnect.php"; //ifl A 9t iil 
if($player name !- '' && $player name !- 'guest')( 
header ("location:hall.php"); 
exit;) 
?» 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"» 
<html xmlns-"http://www.wW3.0rg/1999/xhtml"» 
«head» 
«style» 
body(font-size:15px] 
A:visited ( COLOR: 4000000; TEXT-DECORATION: none) 
A:hover ( COLOR: 4000000; TEXT-DECORATION: underline) 
A:active ( COLOR: #000000; TEXT-DECORATION: none) 
A:link ( COLOR: 4000000; TEXT-DECORATION: none] 
-box( padding:lpx lpx lpx lpx; 
border:lpx solid #487524; 
color:$000; 
FONT-SIZE: 15px; 
text-align: right; 
$ 
.box input( 
padding:lpx lpx lpx 1px; 
border:lpx solid $206300; 
color:£FFFFFF; 
FONT-SIZE: 15px; 
background-color: #FCF; 
} 
.box submit{ 
padding:lpx lpx lpx 1px; 
border:lpx solid #E19D00; 
background:£FFDC04; 
color:$000000; 
FONT-SIZE: 15px;} 


-banq { font-size: 12px; } 
:pl 
text-align: center; 
font-size: 36px; 
color: $900; 
font-weight: bold; 


第 8 章 开心 斗 地 主 


-box tr ta table tr td a froot b t color: 19007 Y 
«/style» 
«meta http-equiv-"Content-Type" content-"text/html; charset-utf-8" /» 
«meta name-"generator" content-"landlord onWeb" /» 
«meta name-"author" content-"mickie" /» 
«meta keyword" content-"mickiedd" /» 
«meta name-"description" content-"qq155448883,CSUST" /» 
<title> 开 心 斗 地 主 1 在 线 斗 地 主 </title> 
</head> 
<body bgcolor="#EBF6E8"> 
<p> 

«?php 
if(isset($ COOKIE [message] ) ) 
t 


echo "<div align-center»".$ COOKIE [message] . "</div>"; 
setcookie (message, NULL); 
} 


po 
«div class="p"> 开 心 斗 地 主 </div><br /> 
«br /> 


«form name-form method-post action-login d.php» 
«table class-"box" align-center»«tr»«td width-"317"» 
«table width-"306" align="center"> 
<tr><td colspan-"2"»«/td»«/tr» 
<tr> 
«td width-"59" align="left"> 账 $: </td> 
<td width="235"><input class=box input type=text name=name id=name 
size=28 maxlenth=12></td></tr> 
<tr> 
«td align="left"> 密 fij: </td> 
<td><input class-box input type-password name-password id-password 
size-28 maxlenth-25»«/td»«/tr» 
«tr»«td»«/td»«td»«input class-box submit type=submit 
name-submit button id-submit button value-t 3» 
<a href-reg.php»«font color-white»«b» 注册 </b></font></a></td></tr> 
«/table» 
«/td»«/tr»«/table» 
«/form»«br /><br /><br /> 
«div align-"center" class="banq"> 开 发 笔记 技术 支持 </div> 
</body> 
</html> 


当 用 户 信息 输入 不 准确 ， 系 统 将 提示 用 户 输入 的 信息 不 准确 ， 需 要 重新 输入 ， 如 图 8-4 


所 示 。 
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下 面 通过 一 段 代 码 进行 讲解 ， 其 代码 (login_d.php) 如 下 : 


<?php 
include "./dbconnect .php";// 调 入 页 面 
if($ POST[name] && $ POST[password]) { 
$sql = mysql query("select count(*) as num from user ddz where name = 
'".$ POST[name]."' and password = '".md5($ POST[password])."'");//Jfd fifi 
if (@mysql_result ($sql, 0, num))( 
setcookie(player name, $_POST [name] ); 
setcookie (player password, md5 ($ POST[password])); 
header ("location:hall.php"); 


}else 

message ("账号 /密码 不 正确 ! ", "index.php"); 
Jelse 
message (" 请 把 资料 填写 完整 ! ", "index.php"); 


?» 


842 注册 用 户 


当 用 户 首次 登录 系统 , 需要 注册 一 个 才能 玩 这 个 网 页 游戏 , 如 图 8-5 所 示 为 网 页 游戏 的 
注册 页 面 。 


Go 
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图 8-5 注册 页 面 


下 面 通过 一 段 代 码 进行 讲解 ， 其 代码 (eg.php) 如 下 : 


«?php 
include "./dbconnect.php"; 
?> 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"» 
<html xmlns-"http://www.w3.0rg/1999/xhtml"» 
<head> 
<style> 
body{font-size:15px; } 
A:visited { COLOR: #000000; TEXT-DECORATION: none} 
A:hover { COLOR: #000000; TEXT-DECORATION: underline} 
A:active { COLOR: #000000; TEXT-DECORATION: none} 
A:link { COLOR: #000000; TEXT-DECORATION: none} 
-box( padding:lpx lpx lpx lpx; 
border:lpx solid #487524; 
background:url(images/f bg.gif); 
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color:£FFFFFF; 
FONT-SIZE: 15px} 

-box input{ padding:lpx lpx lpx 1px; 
border:lpx solid #206300; 
background: #387800; 
color:#FFFFFF; 

FONT-SIZE: 15px} 

-box submit{ padding:lpx lpx lpx lpx; 
border:lpx solid #E19D00; 
background: £FFDC04; 
color:$000000; 

FONT-SIZE: 15px; 


</style> 

<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
<meta nam generator" content-"landlord onWeb" /> 

<meta name="author" content="mickie" /> 

<meta name="keyword" content="mickiedd" /> 


<title> 注 册 </title> 
</head> 

<body bgcolor="#EBF6E8"> 
<?php 


if(isset($ COOKIE[message])) ( 
echo "<div align-center»".$ COOKIE [message] . "</div>"; 
setcookie (message, NULL); } 
om 
«form name-form method-post action-reg d.php» 
«table class="box" align-center»«tr»«td width-"222"» 
«table» 
<tr><td width-"75" align="right"> 账 号 : «/td» 
«td width-"129" colspan=2><input class-"box input" type-text name-name 
size-12 maxlength-12»«/td»«/tr» 
<tr><td align="right">: </td> 
«td colspan=2><input class="box input" type-password name-password size-12 
maxlength-25»«/td»«/tr» 
<tr><td align="right"> 人 确认 密码 : «/td» 
«td colspan-2»«input class-"box input" type-password name-password r 
size-12 maxlength-12»«/td»«/tr» 
«tr»«td»«/td»«td colspan-2»«input class-"box submit" type-submit 
name-submit value= 提 交 ></td></tr> 
</table> 
«/td»«/tr»«/table»«/form«/body»«/html» 


注册 的 时 候 必 须要 按照 规则 填写 ， 如 输入 的 密码 必须 两 次 相同 。 当 注册 不 成 功 时 ， 系 
统 需 要 准确 的 提示 用 户 具体 哪里 不 准确 。 下 面 通过 一 段 代码 进行 讲解 ， 其 代码 (reg_d php) 
如 下 : 


«?php 
include "./dbconnect.php"; //i8 A XE Ilii 
atis ($ PoST[name] && $ POST[password] && $ POST[password r]) ( 
if($ POST[password] != $ POST[password r]) 
message (两 次 输入 的 密码 不 一 致 ， 请 重新 填写 ! , "reg.php"); 
if(strstr($ POST[name], "«")) 
message (账号 不 可 包含 .'"<"'.! , "reg.php"); 
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if(strstr($ POST[name], "»")) 
message (账号 不 可 包含 . n» 1.1 , "reg.php"); 
if(strstr($ POST[name], " ")) 
message (账号 不 可 包含 空格 ! ， "reg.php"); 
$sql = mysql query("select count(*) as num from user ddz where 
name-'".$ POST[name]."'"); 
if((mysql result ($sql, 0, num)) 
message ( 抱 赚 ， 账 号 .$ POST [name] .已 经 存在 ! , "reg.php"); 
$query = mysql query("INSERT INTO 'user ddz' ('ID', 'name', 'password', 
'time', 'face', 'win', 'lost', 'run', 'score') VALUES 
(NULL, '".$ POST[name]."', '".md5($ POST[password])."', 0, 1, 0, 0, 0, 0) ;"); 
if ($query) 
message (注册 成 功 ， 请 登录 游戏 ! , "index.php"); 
else 
echo 注册 失败 ! ; 
}else 
message (资料 填写 不 完整 ! , "reg.php"); 
?» 
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当 用 户 玩 游戏 时 ， 如 果 不 需 要 继续 玩 的 时 候 ， 可 以 退出 游戏 。 退 出 游戏 是 十 分 常见 的 
动作 ， 下 面 通过 一 段 代码 进行 讲解 ， 其 代码 (logout_qd.php) 如 下 : 


<?php 

setcookie (player_name, NULL) ; // 清 除 缓存 里 的 用 户 名 
setcookie(player password，NULL) ;// 清 除 缓存 里 的 密码 
header ("location:index.php"); 

?» 


经 过 两 天 的 时 间 ， 同 事 C 完成 了 用 户 管理 设计 。 我 浏览 完 他 的 设计 代码 ， 深 深 地 明白 
了 用 户 管理 对 游戏 的 重要 性 ， 它 用 来 保存 游戏 的 各 种 资料 与 游戏 者 身份 的 资料 。 在 开发 用 
户 管理 设计 中 ， 用 户 安全 也 至 关 重要 ， 如 果 用 户 的 信息 被 汇 露 ， 造 成 致命 的 打击 。 


8.5 房间 管理 设计 
D 20003 19 28 日 ， 阳 光明 如 


同事 C 刚刚 完成 用 户 管理 模块 的 设计 工作 ， 就 马不停蹄 地 开始 了 房间 管理 模块 的 设计 
和 编码 工作 。 在 刚 开 始 的 时 候 ， 我 觉得 房间 管理 好 像 在 以 前 的 项 目 中 见 过 似 的 ， 但 是 细 想 
之 后 ， 却 也 想 不 起 来 。 下 午 在 淘宝 购物 的 时 候 ， 我 忽然 想起 其 实 一 个 房间 就 是 一 个 类 别 ， 
和 商品 种 类 、 新 闻 类 别 的 实现 原理 完全 一 致 。 想 到 此 处 ， 在 心中 不 禁 感叹 一 一 同事 C 的 房 
间 管 理工 作 其 实 没有 想象 中 的 那么 难 。 
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8.5.1 房间 首页 


当 进 入 系统 后 ， 将 首先 显示 房间 首页 ， 方 便 用 户 选择 需要 的 房间 ， 用 户 可 以 根据 自己 
的 习惯 选择 一 个 房间 ， 如 图 8-6 所 示 。 

(B FOHBE— AF - Windows Internet Explorer ci 
{eer hmps//127.0.0.1/web/o8youdhak. php BEIESE3 EET] P~ 


房间 八 号 


@ intenet | iei sm 


8-6 ”房间 首页 


下 面 通 过 一 段 代 码 进行 讲解 ， 其 代码 (hall.php) 如 下 : 


<?php 
include "./dbconnect.php"; 
e 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"» 
<html xmlns-"http://www.w3.0rg/1999/xhtml"» 
«head» 
«style» 
body{ 
font-size:15px; 
} 
A:visited { 
COLOR: #FFFFFF; TEXT-DECORATION: none 
} 
A:hover { 
COLOR: #FFFFFF; TEXT-DECORATION: underline 
} 
A:active { 
COLOR: #FFFFFF; TEXT-DECORATION: none 


} 
A:link { 

COLOR: #FFFFFF; TEXT-DECORATION: none 
} 


.message box{ 
padding:2px 2px 2px 2px; 
border:3px solid #48648C; 
background: #2C3E57 no-repeat; 
color:#000; 


——————M ————————————————— kasei aai Ed 29! | 
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FONT-SIZE: 15px 
L 
-moved( 
background:url (moved.gif); 
$ 
-over( 
background:url(over.gif); 
} 
</style> 


<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
«meta nam generator" content-"landlord onWeb" /» 
«meta name-"author" content-"mickie" /» 
«meta name-"keyword" content-"mickiedd" /» 
«meta name-"description" content-"qq155448883,CSUST" /» 
«script» 
var http request - false; 
function send request(url) ( 
http request - false; 
if (window.XMLHttpRequest) ( 
http request = new XMLHttpRequest (); 
if (http request.overrideMimeType) ( 
http request.overrideMimeType ('text/xml'); 
} 
} else if (window.ActiveXObject) { 
try ( 
http request = new ActiveXObject ("Msxml2.XMLHTTP"); 
) catch (e) ( 
try ( 
http request - new ActiveXObject ("Microsoft.XMLHTTP"); 
) catch (e) () 


} 
} 
if (!http request) { 
alert (' 不 能 创建 XMLHttpRequest 对 象 !'); 
return false; 
} 
http request.onreadystatechange = processRequest; 
http request.open('GET', url, true); 
http request.send (null); 


) 
// 处 理 返 回信 息 
var text = ''; 
function send r(url,t)( 
type = t; 
send request (url); 
5 
function processRequest() ( 
if (http request.readyState == 1) ( 
//alert(' 正 在 连接 ') ; 
//document.getELementById('network status').innerHTML — "正在 连接 . .7 
f 
if (http request.readyState == 4) { 
if (http request.status == 200) { 
text = http request.responseText; 
H 
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</script> 

<script> 

function open menu (){ 

document .getElementById ("menu") .style.visibility = "visible"; 


document.getElementById("menu").style.top = event.clientY + 'px' ; 
document.getElementById("menu").style.left = event.clientX + 'px'; 
} 

function close menu (){ 
document.getElementById("menu").style.visibility = "hidden"; 


document.getElementById("menu").style.top = event.clientY + 'px' ; 
document.getElementById("menu").style.left = event.clientX + 'px'; 
} 

</script> 

<title> 开 心 斗 地 主 一 一 大 厅 </title> 

</head> 


<body bgcolor="#51719E" topmargin="0" leftmargin="0" rightmargin="0" 
bottommargin="0"> 
<table width=100% border="0" cellpadding="0" cellspacing="0"> 
<tr><td height=36 background-"images/top bar.gif" nowrap-"nowrap" 
width-100$»&nbsp;«font color=white> 现 在 位 置 : 斗 地 主 onWeb «/font»«/td»«td 
nowrap-"nowrap" width-"120" background-"images/top bar.gif" 
align-"right"»«a href-"logout d.php"»«font color-"white"»ikfH 
«/font»«/a»&nbsp;«/td» 
«/tr» 
<tr><td colspan-"2" align-"center"»«div id-"rooms"» 
«font color-white»loading...«/font»«/div»«/td»«/tr»«/table» 
«script» 
function get rooms()( 

send request ("get rooms.php?time-"-4Math.random()); 

if(text) 

document .getElementById ("rooms") .innerHTML = text; 


} 

get_rooms (); 

setInterval ("get rooms ()", 1000); 
</script> 

</body> 

</html> 


8.5.2 选择 房间 


在 房间 首页 呈现 出 不 同 的 房间 ， 用 户 需 要 选择 一 个 要 进入 的 房间 。 当 用 户 选择 一 个 房 
间 后 ， 程 序 将 要 为 它 准确 地 处 理 ， 下 面 将 通过 一 段 代 码 进行 讲解 ， 其 代码 (ioinphp) 如 下 : 


<?php 
include "./dbconnect .php";// 调 入 页 面 
$sql = mysql query("select count(*) as num from room ddz where playerl name 
= '$player name' or 
player2 name = '$player name' where ID = '".$ GET[ID]."'"); 
if(@mysql result($sql, 0, num)) ( 
header ("location:room ddz.php?ID-".$ GET[ID]); 
exit; 
}else{ 
$sql = mysql query ("select count (*) as num from user ddz where name = 
'$player_name'"); 
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if (!@mysql result ($sql, 0, num)) 
{// 返 回 数据 结果 
header ("location:index.php"); 
exit; 


$sql = mysql query ("select * from room ddz where ID = 
'".$ GET[ID] ." 17) ;// 数 据 查询 
$num = mysql num rows ($sql);// 获 取 行 信息 
if(!$num) 
die (参数 有 误 ! ); 
$playerl name = mysql result($sql, 0, playerl name); 
$player2 name = mysql result($sql, 0, player2 name); 
if($playerl name && $player2 name) 


header ("location:hall.php"); 
exit; 
} 
if($playerl name == '') 
t 
mysql query ("update room ddz set playerl name = '$player name', 
playerl time = '$ori time', system time = '$ori time' where ID = 
ume SGEDI ED] m my 
header("location:room ddz.php?ID-".$ GET[ID]); 


exit; 
) 
if($player2 name == '') 
t 
mysql query ("update room ddz set player2 name = '$player name' 
, player2 time = '$ori time', system time = '$ori time' where ID = 
oe S GET[ID]."'"); 
header ("location:room ddz.php?ID=".$ GET[ID]); 
exit; 


单 易 用 至 上 


仅仅 耗 时 一 天 ， 同 事 C 就 完成 了 房间 管理 模块 的 编码 和 设计 工作 。 我 体会 到 这 是 一 个 
多 人 共同 玩 的 网 页 游戏 ， 开 发 者 创建 房间 ， 组 织 每 一 个 用 户 来 玩 棋牌 游戏 ， 在 开发 棋牌 游 
戏 的 过 程 中 ， 在 房间 首页 阶段 通常 会 走 弯路 ， 容 易 选 择 许多 漂亮 的 方案 。 其 实 我 们 的 最 终 
目的 是 最 简单 易 用 供用 户 选择 房间 ， 并 开始 游戏 。 总 结 完毕 后 ， 我 决定 早点 休息 ， 为 明天 
的 工作 养 精 蓄 锐 。 


86 i$ X 
(200903 15 30 日 ， 阳 光明 媚 


刚 完 成 房间 管理 的 设计 编码 工作 ， 就 马上 开始 了 下 一 阶段 一 一 游戏 模块 的 设计 编码 工 
作 。 因 为 此 阶段 的 重要 性 ， 在 开始 之 前 我 、 同 事 C 和 同事 B 进行 了 专门 交流 讨论 ， 明 确 了 
选择 房间 和 游戏 规则 这 两 个 核心 问题 。 
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8.6.1 选择 房间 


当 进 入 系统 后 ， 如 果 只 有 自己 一 个 人 ,用 户 可 以 邀请 朋友 来 玩 ， 如 图 8-7 所 示 ， 房 间 内 
没有 其 他 人 时 ， 需 要 邀请 一 位 朋友 才能 玩 游戏 。 

[ B FOLE - Windows Internet Explorer me) 

e )v [© npwazzoaavcboaouirconsdcphpmm-: -| Ren | X [E aer. P~ 


ġa- Dam y0 oA 


@ interret | init NA fa ^ 10096 

图 8-7 ”邀请 朋友 
下 面 通 过 一 段 代码 进行 讲解 ， 其 代码 如 下 : 
<?php 
include "./dbconnect.php"; 
$sql = mysql query("select * from room ddz where ID = '".$ GET[ID]."'"); 
$num = mysql num rows ($sql); 
if(!$num) 


die (房间 不 存在 ! ); 


$name = mysql result ($sql，0，name);// 获 取 结 果 信息 
$playerl name = mysql result($sql, 0, playerl name) ;// 房 间 设置 
$player2 name = mysql_result ($sql，0，player2_name);// 房 间 设 置 


if(Splayer name == '' || ($player name != $playerl name && $player name != 
$player2 name)) 

t 

header ("location:join.php?ID-".$ GET[ID]); 

exit; 

) 


?» 

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"» 

<html xmlins-"http://www.w3.0rg/1999/xhtml"» 

<head> 

<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 


<meta generator" content-"landlord onWeb" /> 
«meta author" content-"mickie" /> 
«meta keyword" content-"mickiedd" /» 


«meta name-"description" content-"qq155448883,CSUST" /> 
<title> 开 心 斗 地 主 </title> 

«style» 

body(font-size:15px; color:white; } 

A:visited ( COLOR: 4000000; TEXT-DECORATION: none] 
A:hover ( COLOR: 4000000; TEXT-DECORATION: underline] 


< 
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A:active { COLOR: #000000; TEXT-DECORATION: none] 
A:link { COLOR: #000000; TEXT-DECORATION: none] 
</style> 

<span id="point" style="display:none"><img src=images/point.gif></span> 
<span style="display:none"> 

<img src="images/loading.gif" /> 

<img src=images/show_hand.gif> 

<img src=images/no show hand.gif> 

<img src=images/lord.gif> 

<img src=images/no lord.gif> 

<img src=images/NO.gif> 

<img src=images/BG.gif> 


</span> 

«div style-"display:none" id-"playerl sound"></div> 
«div style-"display:none" id-"player2 sound"»«/div» 
«div style-"display:none" id-"public sound"»«/div» 
«script src-"dd code.js"»«/script» 

«script» 

// 公 用 


function sound (object, name) { 
document.getElementById (object).innerHTML = 

dd code (' [wmp] '+name+' [/wmp] ') ; 
} 
function copy url()( 
if(window.clipboardData.setData('text',document.location.href.replace 
('room ddz.php','guest.php'))) 
alert (' 复 制 成 功 ! Ctrl + v 把 地 址 发 送 给 好 友 ') ; 
) 
«?php 
echo "var playerl name - '".$playerl name."';"; 
echo "var player2 name '".$player2 name."';"; 
echo "var player name = '".$player name."';"; 
if($player name $playerl name) 
echo "player ID Iplayertirt 
else 
echo "player ID - 'player2';"; 
?> 
var flag = ''; 
function GetRandomNum (Min,Max) {// 随 机 取 数 

Var Range = Max - Min; 

var Rand = Math.random(); 

return(Min + Math.round(Rand * Range)); 


) 


var main echo - ''; 
var status - 'begin'; 
var now flag = ''; 


var http request - false; 
function send request (url) {// 探 寻 信息 
http request = false; 
if (window.XMLHttpRequest) ( 
http request = new XMLHttpRequest () ; 
if (http request.overrideMimeType) ( 
http request.overrideMimeType ('text/xml'); 


} 
) else if (window.ActiveXObject) { 
try ( 


http request - new ActiveXObject ("Msxml2.XMLHTTP"); 
} catch (e) ( 
CRENGI 


ee TT TTT - 
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http request = new ActiveXObject ("Microsoft.XMLHTTP"); 
) catch (e) {} 
$ 
} 
if (!http request) { 
alert (' 不 能 创建 XMLHttpRequest XI$!'); 
return false; 
) 
http request.onreadystatechange = processRequest; 
http request.open('GET', url, true); 
http request.send (null); 


) 
// 处 理 返回 信息 
var type = 0; 
function send r(url,t)( 
type = t; 
send request (url); 
} 
function processRequest() {// 处 理 请 求 
if (http request.readyState == 1) ( 
//alert (' 正 在 连接 '); 
//document.getELementById('network status').innerHTML = ' 正 在 连接 ..'; 
} 
if (http request.readyState == 4) { 
if (http request.status == 200) ( 
if (type == O)( 
var text = http request.responseText.split("|"); 
playerl name = text[0]; 
player2 name = text[1]; 
lord = text[4]; 
lord p = text[5]; 
flag = text[6]; 
if (status != 'wait'){ 
do ani p(text[3]); 
do self p(text[2]); 
do user info(text[9], text[10], text[11], text[12], 
text[13], text[14]); 
$ 
player1 show 
player2 show 


text[7]; 
text[8]; 


8.6.2 游戏 规则 


鞠 游 戏 必须 遵守 游戏 规则 ， 斗 地 主 也 是 一 样 ， 出 牌 不 能 乱 出 ， 必 须 遵 守 一 定 的 规则 ， 
下 面 通 过 一 段 代码 进行 讲解 。 

1. 出 牌 普通 规则 

出 牌 时 ， 有 些 普通 的 规则 需要 遵守 ， 下 面 通过 一 段 代码 进行 讲解 ， 其 代码 如 下 : 


yt » | 297 | 


se r 
V 深入 体验 PHP 项 目 开发 


// 规 则 

function pai v(pai)t 
var v; 
if (pai == '3' || pai == 'F3' || pai == 'T3' || pai == 'H3') 
v= 3; 
if (pai == '4' || pai == 'F4' || pai == 'T4' || pai == 'H4') 
v= 4; 
if (pai == '5' || pai == 'F5' || pai == 'T5' || pai == 'H5') 
v= 5; 
if (pai == '6' || pai == 'F6' || pai == 'T6' || pai == 'H6') 
v=6; 
if (pai == '7' || pai == 'F7' || pai == 'T7' || pai == 'H7') 
yT 
if (pai == '8' || pai == 'F8' || pai == 'T8' || pai == 'H8') 
[OT 
if (pai == '9' || pai == 'F9' || pai == 'T9' || pai == 'H9") 
EO 
if(pai == '10' || pai = 'F10' || pai == 'T10' || pai = 'H10") 
v = 10; 
if(pai == '11' || pai == 'F11' || pai == 'T11' || pai == 'H11'") 
v= 11; 
if(pai == '12' || pai == 'F12' || pai == 'T12' || pai == 'H12') 
v = 12; 
if(pai 
v 7 13; 
if(pai == '1' || pai = 'F1' || pai == 'T1' || pai == 'H1') 
v = 14; 
if (pai == '2' || pai == 'F2' || pai == 'T2' || pai == 'H2') 
v = 15; 
if(pai == 'JOKEl') 
v= 16; 
if(pai == 'JOKE2') 
v= 17; 
if (pai == 'NO') 
NP dE 
return v; 


Wea esa ra E= 


} 
function pai a(pai)( 
// 返 回 为 1 
var split pai = pai.split(","); 
var pai num = split pai.length - 1; 
var count = new Array(1,1,1,1,1,1,1,1,1,1,1,1); 
var k = 0; 
for(var i = 1;i < pai num;i ++) 


t 
if(pai v(split pai[i]) == pai v(split pai[i - 11)) 
count[k] ++; 
else 
k ++; 
} 
War E= na 
for(var i = 0;i < count.length;i ++) 
t 
ror countpilrts". 
H 


2. 对 子 的 出 牌 规则 
在 斗 地 主 的 时 候 ， 有 打 对 子 的 习惯 ， 所 谓 对 子 ， 就 是 两 个 或 者 两 个 以 上 一 样 的 牌 ， 如 


(298 KKS ————————————————————— ON z 


图 8-8 所 示 。 
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图 8-8 对 子 
下 面 通过 一 段 代码 进行 讲解 ， 其 代码 如 下 : 
// 对 
if(pai num — 2 && r == '2,1,1,1,1,1,1,1,1,1,1,1,') 
return pai c(pai v(split pai[0]), pai num, 'dui'*pai v(split pai[0])); 
Jess! 
if(pai num == 3 && r == '3,1,1,1,1,1,1,1,1,1,1,1, ') 
return pai c(pai v(split pai[0]), pai num, 'san'); 
// 四 只 
if(pai num = 4 && r — '4,1,1,1,1,1,1,1,1,1,1,1, ) 


return pai c(pai v(split pai[0]), pai num, 'zha'); 


// 四 带 两 只 


if(pai num == 6 && (r == '4,1,1,1,1,1,1,1,1,1,1,1,' || r = 
| r — '1,1,4,1,1,1,1,1,1,1,1,1, ')) 


'1,4,1,1,1,1,1,1,1,1,1,1,' | 
{ 
if(count[0] == 4) 


return pai c(pai v(split pai[3]), pai num, 
else if(count[1] = 4) 
return pai c(pai v(split pai[4]), pai num, 
else if(count[2] == 4) 
return pai c(pai v(split pai[5]), pai num, 


) 

// 四 带 两 对 

if(pai num — 8 && (r 

'2,4,2,1,1,1,1,1,1,1,1,1,' | 

d 
if(count[0] == 4) 
return pai c(pai 
else if (count[1] 
return pai c(pai 
else if (count[2] 
return pai c(pai 


'sidaier'); 
'sidaier'); 


'sidaier'); 


n0074:272 0451517 15:17:17 947 E 
| !2,2,4,1,1,1, 1, 1,3, 3, V5 1, 1) 


v(split pai[3]), pai num, 
m— 
v(split pai[5]), pai num, 
EE 
v(split pai[7]), pai num, 


'sidailiangdui'); 
'sidailiangdui'); 


'sidailiangdui'); 


bad 
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ES 

有 
'1,3,1,1,1,1,1,1,1,1,1,1,')) 

{ 


if(count[0] > count[1]) 
return pai c(pai v(split pai[2]), pai num, 'sandaiyi'); 
else 
return pai c(pai v(split pai[3]), pai num, 'sandaiyi'); 
) 
IA EE 
if(pai num — 5 && (r — '3,2,1,1,1,1,1,1,1,1,1,1,' || r — 
'2,3,1,1,1,1,1,1,1,1,1,1, ')) 


t 
if(count[0] » count[1]) 
return pai c(pai v(split pai[2]), pai num, 'sandaiyidui'); 
else 
return pai c(pai v(split pai[4]), pai num, 'sandaiyidui'); 
) 
// 连 对 
if((pai num == 6 && r == '2,2,2,1,1,1,1,1,1,1,1,1,') || (pai num == 
BESSER 220220 TETTE TA TTE PONTI pas nam 10 && r — 
10325222 42 dq dede nn = 
ED Ty a num 14 && 
12922090 2242: TT T TT STI (paie num 16 && 
DO aie num 18 && 
1082225282608232 08] TT paa num 320855 
'2,2,2,2,2,2,2,2,2,2,1,1,')) 
{ 


var flag = 0; 
for(var i = 2;i < pai num;i += 2) 
{ 
if(pai v(split pai[i]) - pai v(split pai[i - 1]) != 1) 
t 
flag = 1; 
break; 
} 
} 
if(flag == O)( 
return pai c(pai v(split pai[pai num- 1]), pai num, 'liandui'); 


) 
) 
// 飞 机 
if((pai num — 34342 && (r -- '3,3,2,1,1,1,1,1,1,1,1,1,' || r —- 
'2,3,3,1,1,1,1,1,1,1,1,1,')) || (pai num == 3434242 && (r == 
'3,3,2,2,1,1,1,1,1,1,1,1,' || r — '2,3,3,2,1,1,1,1,1,1,1,1,' || r = 
a T br Edd) 90] 9 (paitnum = Sri £850 (5 — 
n3 3 npa nara ed nEcc-—uniaana qudd eq pa 
Valete rea ben easi tA DAR Toa iy A TaT 
t 
if(count[0] == 3 && count[1] == 3 && pai v(split pai[3]) - 
pai v(split pai[2]) = 1) 


return pai c(pai v(split pai[3]), pai num, 
*!re19]3)7//3322533117332 


if(count[0] — 2 && count[1] == 3 && pai v(split pai[5]) - 
pai v(split pai[4]) == 1) 

return pai c(pai v(split pai[5]), pai num, 'feiji');//2332,233 

if(count[0] == 1 && count[1] == 3 && pai v(split pai[4]) - 
pai v(split pai[3]) — 1) 


return pai c(pai v(split pai[4]), pai num, 'feiji');//1331 
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if(count[0] == 2 && count[1] == 2 && pai v(split pai[7]) - 
pai v(split pai[6]) == 1) 
return pai c(pai v(split pai[7]), pai num, 'feiji');//2233 
if(count[0] == 1 && count[1] == 1 && pai v(split pai[5]) - 
pai v(split pai[4]) == 1) 
return pai c(pai v(split pai[5]), pai num, 'feiji');//1133 
) 
// 对 王 
if (pai num == 2 && ((pai v(split pai[0]) ==16 && pai v(split pai[1]) 
== 17) || (pai v(split pai[0]) == 17 && pai v(split pai[1]) == 16))) 
return pai c(100, pai num, 'wangzha'); 
ES 
if(pai num -- 1) 


return pai c(pai v(split pai[0]), pai num, pai v(split pai[0])); 


3. 顺 子 的 出 牌 规则 
如 果 你 的 牌 是 顺 子 ， 也 可 以 连 着 出 牌 ， 但 是 顺 子 数量 必须 要 大 于 等 于 5 张 才能 出 牌 ， 
小 于 这 个 数 的 顺 子 都 不 能 出 牌 ， 如 图 8-9 所 示 。 
| Æ TE sib - Windows Internet Explorer [rom 
QOO e we vum 


图 8-9 JT iS 
下 面 通过 一 段 代 码 进 行 讲解 ， 其 代码 如 下 : 
// 顺 子 


if(pai v(split pai[pai num - 1]) 
<= pai v(1) && pai num >= 5 && r 
== '1,1,1,1,1,1,1,1,1,1,1,1, ') 
t 
var flag - 0; 
for(var i = 1;i < pai num;i ++) 


t 
if(pai v(split pai[i]) = pai v(split pai[i - 1]) !- 1) 
t 
flag = 1; 
break; 


—————————— ———— ——————— € » 
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} 
if(flag — 0) 
return pai c(pai v(split pai[pai num- 1]), pai num, 'shunzi'); 


return Array(0,0,0); 
) 
function pai c(v,num, t)( 
var arr - new Array(); 
arr[0] = v; 


arr[1] = num; 
arr[2] = t; 
return arr; 

$ 

//----------- END 


var p = new Array(); 
var ani count = 0; 


var lord = ''; 
var playerl show = ''; 
var player2 show = ''; 


function no show p() 
{ 


var p show var = 'NO,'; 
send r("show p.php?ID- 
«?php 


echo $ GET[ID];?» 
&player ID-"«player ID+"&P show var="+p show var*"&time-"4Math.random(),1); 
) 


4. 提示 信息 
当 一 用 户 出 牌 不 符合 规则 ， 需 要 系统 对 用 户 进行 提示 ， 如 图 8-10 所 示 为 出 牌 规则 不 符 
合 的 提示 信息 。 
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Le iw e) manane m cdzch "| 81 [x a ar-r. cx 
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下 面 通 过 一 段 代码 进行 讲解 ， 其 代码 如 下 : 


function show p(( 
if(flag != player ID) 
alert("It's not your turn now!"); 


else{ 
var p show = new Array(); 
var p show var = ''; 


var j = 0; 
for(var i = 0;i < p.length - 1;i ++) 


t 
if(document.getElementById('self p top '+p[i]) . innerHTML) 
t 
p show[j ++] = p[i]; 
p show var += p[i]+','; 
} 
H 
if(p show var == '') 
alert ( "你 还 没有 选取 牌 ! ') ; 
else( 
var self pai - pai a(p show var); 
if (player ID == 'playerl') 
i 
if(player2 show) 
var ani pai = pai a(player2 show); 
else 
var ani pai - new Array(0,0); 
}else{ 
if(playerl show) 
var ani pai - pai a(playerl show); 
else 
var ani pai - new Array(0,0); 
) 
if(self pai[0] && (self pai[0] == 
100 || ani pai[0] == II (ani pai[0] !- 100 && ((self pai[1] == 
ani pai[1] && self pai[0] - ani pai[0] > 0) || self pai[2] == 'zha')))) 


send r("show p.php?ID-«?php echo 
$ GET[ID];?»&player ID="+player ID+"&P show var= 
"+p show var*"&time-"-«Math.random(),1); 

else 


alert (" 你 的 出 牌 不 符合 规则 ! 0) ; 


} 
} 
var sound count = 0; 
function do show p(p ori,object)( 
if(playerl show == '' && player2 show == '')( 


}else{ 
var arr playerl show = pai a(playerl show); 
var arr player2 show = pai a(player2 show); 
if((arr player2 show[1] == arr playerl show[1]) && 
playerl show && player2 show) 
t 
Sound count ++; 


àd 


d 


War 一 


) 


if (sound count > 3 || arr playerl show[2] == '0' 
|| arr player2 show[2] == "0' || arr playerl show[0] == "100" 
|| arr player2 show[0] == '100' || arr playerl show[2] == 'zha' |l 
arr player2 show[2] == 'zha') 


sound count = 0; 


if (sound count == 0){ 
var arr = pai a(p ori); 


if(arr[2] == '0') 
arr[2] = 'NO'+GetRandomNun (1, 4); 


sound (player ID+' sound','./sound/'+arr[2]+'.wav'); 
}else if (sound count > 0){ 

sound (player ID+' sound','./sound/dani'+sound count+'.wav'); 
) 


var split p — p ori.split(","); 
var show = '«table align-center border-"0" cellpadding-"0" 
cellspacing-"0"»«tr»'; 
for(var i = 0;i < split p.length - 1;i ++) 
t 
Show += '«td background-"images/'«*split p[i]*'.gif" 
width-'-(i--split p.length-1-1?'71':'36')«"' 
height-96»«/td»'; 
} 
Show += '«/tr»«/table»'; 
document .getElementById (object) .innerHTML = show; 
} 
function click p(p){ 
if(document.getElementById('self p top '+p).innerHTML) 
document.getElementById('self p top '+p).innerHTML = ""; 
else 
document.getElementById('self p top '«p).innerHTML = 
document.getElementById('point').innerHTML; 
} 


| 209719290, & — 
今天 完成 了 游戏 的 编写 程序 。 在 编写 程序 的 时 候 ， 要 注意 选择 房间 的 方法 和 游戏 规则 ， 


游戏 规则 是 核心 ， 规 则 编写 十 分 困难 也 很 重要 ， 短 短 的 近 百 行 代码 ， 算 法 却 都 在 里 面 ， 定 
制 了 出 牌 的 规则 。 
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我 们 看 到 胜利 的 曙光 了 ， 最 后 的 项 目测 试 工作 由 我 来 完成 。 在 此 我 将 工程 命名 为 
“08youxi”， 如 图 8-11 所 示 为 正在 游戏 的 界面 。 
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图 8-11 正在 游戏 


8.7.1 系统 运行 预览 


当 用 户 进入 系统 后 ， 与 好 友 进 行 斗 地 主 ， 按 照 规则 出 牌 是 一 件 十 分 有 趣 的 事情 ， 如 

图 8-12 所 示 为 正在 玩 斗 地 主 的 游戏 。 
(bro -Windows iemet plorer | 
TO DE EEIESTEZE - E 


按照 规则 我 已 把 项 目 全 部 交 给 总 经 理 进 行 验收 ， 将 代码 挂 在 我 的 电脑 上 ， 供 整个 局 域 


Var 一 


网 里 的 同事 游戏 ， 经 过 两 三 天 的 测试 ， 总 经 理 十 分 赞赏 这 个 游戏 。 虽 然 游 戏 很 好 玩 ， 总 经 
理 要 求 只 能 在 中 午时 间 玩 ， 不 能 在 上 班 时 间 玩 。 


873 总结 


对 于 长 期 从 事 游戏 开发 的 程序 员 来 说 ， 这 个 项 目 十 分 简单 ， 但 是 初学 者 可 以 从 中 获取 
一 些 游戏 开发 的 经 验 。 虽 然 时 间 紧 迫 ， 但 是 仍然 完成 了 这 个 项 目的 开发 ， 深 刻 地 体会 到 游 
戏 策划 和 程式 设计 的 重要 性 。 

1) 游戏 策划 很 重要 

要 制作 一 个 合格 的 游戏 ， 如 果 没 有 一 个 好 的 策划 ， 那 么 这 个 游戏 可 能 很 难 做 成 。 可 能 
一 些 有 这 方面 爱好 的 程序 员 也 会 编写 游戏 ， 比 如 五 子 棋 、 俄 罗斯 方块 等 ， 但 不 加 强 专业 练 
习 也 难 成 大 气 。 有 成 熟 经 验 的 游戏 开发 人 员 ， 一 般 会 成 立 小 创作 群 都 是 策划 兼程 式 设计 。 
那么 策划 要 做 些 什么 呢 ? 确定 运行 游戏 的 操作 系统 ， 分 析 操 作 系统 优点 和 缺点 ， 确 定编 程 
语言 。 游 戏 自身 的 定位 ， 适 合 于 哪 类 人 群 玩 。 游 戏 规则 的 制定 ， 关 系 到 整个 游戏 命运 。 万 
地 高 楼 平地 起 ， 设 计 一 套 流行 的 游戏 模式 至 关 重要 ， 这 也 是 高 手 所 干 的 活 儿 。 

2) 程式 设计 很 重要 

选择 一 种 合适 团队 的 计算 机 语言 和 编译 器 ， 这 对 游戏 制作 来 说 可 是 相当 重要 的 。 如 果 
在 游戏 制作 到 过 半 时 发 现 这 一 语言 编程 不 方便 或 编译 器 不 好 ， 沁 不 让 人 伤心 。 所 以 在 设计 
一 个 游戏 前 一 定 要 选择 好 编程 语言 和 编译 器 。 不 一 定 在 游戏 开发 过 程 中 处 处 遵循 当今 流行 
的 面向 对 象 编程 ， 面 向 对 象 编程 也 有 着 它 的 致命 弱点 。 就 拿 C++ 在 Windows 98 下 编 游戏 来 
i: 如 果 以 面向 对 象 的 形式 进行 编程 ， 程 序 自动 创建 的 类 将 会 变 得 非常 多 ， 此 时 采用 面向 
过 程 更 加 简洁 。 所 以 采用 何 种 编程 方式 根据 实际 情况 而 定 。 


E < 和 和 和 让 人 和 证 z 
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博客 管理 系统 是 一 个 供 人 们 抒发 情感 的 、 人 与 之 间 之 
间 进 行 沟通 的 平台 ， 它 是 继 聊天 室 、 论 坛 、QQ 后 ， 又 一 
划时代 产品 。 微 博 是 博客 的 一 个 衍生 ， 如 果 说 博客 是 长 篇 
大 论 的 沟通 ， 微 博 则 是 实时 短小 的 沟通 。 如 果 把 博客 比 作 
书信 的 话 ， 那 么 微 博 就 是 短信 人。 

在 本 章 的 内 容 中 ,将 详细 讲解 微型 博客 管理 系统 的 构 
建 ， 旨 在 让 读者 牢固 掌握 SQL 后 台数 据 库 的 建立 、 维 护 
以 及 前 台 应 用 程序 的 开发 ， 为 以 后 深入 地 学 习 打 下 坚实 的 
基础 。 


V 深入 体验 PHP 项 目 开发 


9.1 微 博 ， 让 生活 更 美好 


人 生 ， 有 太 多 的 故事 想 讲 了 ， 长 的 、 短 的 ， 以 前 总 把 这 些 记 在 日 记 本 里 ， 现 在 有 了 博 
客 ， 可 以 发 布 在 网 络 上 。2009 年 ， 博 客 的 衍生 品 微 博 问世 ， 提 供给 大 家 写 短小 的 博客 ， 让 
成 千 上 万 的 网 民 一 片 沸腾 。 它 ， 改 变 了 我 的 生活 。 


9.1.1 项 目 来 源 
| 3200588159, A6 — 


公司 来 了 新 项 目 ， 为 了 增加 公司 网 站 的 人 气 ， 决 定 开发 微 博 平台 ， 总 经 理 给 我 打 来 电 
话 ， 说 公司 网 站 访问 量 最 近 开 始 下 滑 ， 微 博 已 经 成 为 时 代 的 利器 ， 想 通过 微 博 平台 来 汇聚 
人 和气 。 我 这 个 项 目 组 又 来 了 新 的 成 员 ， 我 尝试 让 他 们 融合 ， 开 发 一 个 易 用 的 微 博 。 


9.4.2. 组建 团队 


(02300588200, 8. — 

下 了 几 天 的 雨 ， 一 直 没 有 停 过 ， 弄 得 人 心烦 ， 项 目 不 大 ， 由 项 目 组 共同 完成 。 团 队 成 
员 如 下 。 

同事 A: 


他 来 自 东 北 ， 在 重庆 读 了 4 年 书 ， 读 完了 不 准 离开 这 座 漂亮 而 繁华 的 城市 ， 他 喜欢 上 
南山 看 着 整个 城市 的 风景 。 他 在 重庆 找 了 女 朋友 ， 关 系 其 好 ， 看 来 这 华 子 与 重庆 结 下 了 不 


解 之 缘 了 。 
任务 : 负责 项 目 规划 ， 扎 写 系统 设计 规划 书 。 
同事 B: 


他 来 自 万 州 ， 他 除了 喜欢 计算 机 外 ， 还 喜欢 雕刻 ， 从 事 软 件 设计 已 经 半年 了 ， 对 需求 
分 析 和 数据 库 设 计 比 较 有 天 赋 。 
任务 : 负责 需求 分 析 和 数据 库 设计 。 
同事 C: 
他 是 我 的 同学 ， 在 家 里 呆 了 好 多 天 了 ， 一 直 没 有 找到 工作 ， 我 看 公司 有 空 职 位 ， 特 叫 
他 来 面试 ， 没 有 想到 面试 成 功 了 。 
任务 : 负责 设计 系统 信息 管理 模块 和 微 博 管理 模块 。 
我 : 
目前 是 公司 项 目 组 组 长 ， 是 代 界 一 只 待 飞 的 小 鸟 。 
任务 : 负责 系统 整体 框架 设计 ， 并 协调 项 目 中 各 个 模块 的 进展 。 
具体 职能 结构 如 图 9-1 所 示 。 
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同事 A 


B 
RERBA. M E. d 
写 系统 设计 规划 书 


数据 库 设 计 
z 


9-1 职能 结构 图 


整个 项 目的 具体 操作 流程 是 ， 项 目 规划 一 数据 库 设计 一 框架 设计 一 用 户 信息 管理 、 微 
博信 息 管理 、 微 博 系 统管 理 。 

9.4.3 小 会 议 
[om3]o$3692(9,*4 — — 


下 了 一 周 的 雨 ， 天 气 终于 放晴 了 ， 在 夏天 应 该 说 是 一 件 舒 服 的 事情 ， 因 为 不 太 热 ， 空 
调 甚至 都 可 以 不 开 ， 我 将 项 目 组 的 成 员 组 织 在 一 起 ， 讨 论 微 博 开发 的 重点 难点 ， 首 先 我 做 
了 讲解 ， 关 于 微 博 的 关键 技术 和 困难 之 处 ， 以 及 项 目的 工作 量 。 接 着 就 是 大 家 一 起 讨论 。 

最 后 我 做 了 一 个 简单 的 总 结 : “要 开发 一 个 微 博 系统 ， 首 先 要 进行 系统 需求 分 析 和 总 
体 设 计 、 分 析 系 统 的 使 用 对 象 和 用 户 需求 、 设 计 系统 的 体系 结构 和 数据 库 表 结构 、 决 定 使 
用 的 开发 工具 和 后 台数 据 库 、 规 划 项 目的 开发 进度 等 。” 

大 家 一 致 提议 同事 A 尽快 作出 规划 书 ， 后 续 工 作 将 以 规划 书 为 基础 进行 扩展 。 


9.2 ”系统 概述 和 总 体 设计 


(— 2000585220, 阳光 明媚 
同事 A 经 过 两 天 的 努力 ， 做 出 了 项 目 规划 书 ， 整 个 规划 书 分 为 如 下 两 个 部 分 。 
OQ “系统 需求 分 析 
口 系统 运行 流程 

9.2.1 系统 需求 分 析 


微 博 是 一 个 留言 很 少 的 功能 模块 ， 主 要 用 于 网 民 交 互 ， 它 的 具体 功能 如 下 。 


——————————— ———— ——— MÀ 之 ED 


V 深入 体验 PHP 项 目 开 发 


1. 留言 信息 模块 


留言 信息 模块 是 针对 拥有 微 博 的 个 人 ， 他 可 根据 自身 的 需要 随时 在 微 博 上 留言 ， 或 者 
发 照片 与 网 友 们 分 享 。 


2. 评论 管理 


当 博 主 发 表 了 文字 或 者 照片 等 信息 ， 应 管理 和 网 友 的 交互 功能 ， 网 友 可 以 对 其 评论 ， 
但 是 也 不 妨 有 恶意 中 伤 的 评论 ， 需 要 对 其 进行 管理 。 


3. 微 博 管 理 
微 博 是 一 个 自 定义 的 微小 博客 ， 用 户 可 以 根据 自己 的 需要 改变 名 称 和 头像 ， 以 及 设置 
微 博 的 显示 方式 。 


9.2.2 ”系统 运行 流程 


在 此 模拟 了 系统 的 运行 情景 : 运行 系统 后 ， 首 先 会 弹出 用 户 登 录 对 话 框 ， 对 用 户 的 身 
份 进行 认证 ， 并 确定 用 户 的 类 型 。 如 果 是 普通 浏览 者 ， 只 能 允许 浏览 和 评论 微 博 的 文章 ， 
如 图 9-2 所 示 。 
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9-2 (BE 


仅仅 耗 时 一 天 ， 同 事 A 的 系统 规划 工作 大 功 告 成 。 有 了 这 个 规划 书 ， 我 们 以 后 的 工作 
就 有 目的 性 了 。 接 下 来 ， 需 要 同事 B 出 马 来 完 成 数据 库 设计 工作 。 
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9.3 ”数据库 设计 


有 了 前 面 同事 A 设计 的 规划 书 , 同事 B 的 数据 库 设 计 工作 就 很 有 目的 性 了 。 都 说 一 个 
成 功 的 软件 系统 ， 是 由 50% 的 业务 加 50% 的 软件 所 组 成 ， 而 50% 的 成 功 软件 又 是 由 25% 的 
数据 库 加 25% 的 程序 所 组 成 ， 数 据 库 设 计 的 好 坏 是 一 个 关键 。 如 果 把 企业 的 数据 比 作 生命 
所 必需 的 血液 ， 那 么 数据 库 的 设计 就 是 应 用 中 最 重要 的 一 部 分 。 幸 亏 团队 中 的 同事 B 是 数 
据 库 方面 的 专家 ， 仅 仅 耗 时 一 天 ， 整 个 数据 库 就 设计 完毕 了 。 


9.3.1 数据 库 结构 设计 


具体 的 数据 库 设 计 ， 同 事 B 参考 了 同事 A 的 需求 分 析 。 由 需求 分 析 的 规划 可 知 整个 项 
目 对 象 有 3 种 信息 ， 所 以 对 应 的 数据 库 也 需要 包含 这 3 种 信息 ， 从 而 系统 需要 包含 以 下 3 

O wb blog: 微 博 内 容 信息 表 

O wb comment: 微 博 评论 信息 表 

O wb friend: 微 博 配 置信 息 表 

同事 B 给 出 了 具体 数据 库 表 的 书面 文件 如 下 。 

(1) 微 博 内 容 信 息 表 (wb_blog)， 用 来 保存 微 博 发 表 的 信息 ， 表 结构 如 表 9-1 所 示 。 


表 9-1 微 博 内 容 信 息 表 


字段 类 型 整理 属性 Nul RU 格外 
mid mediumint(8) E auto increment 
message —char(140) utf8 general ci 8 
picture char(50) uff8 general ci Ej 
dateline — int(10) 8 
origin char(10) utf8 general ci E 
comments mediumint(8) EJ 


(2) 微 博 评论 信息 表 (wb_comment)， 用 来 保存 微 博 评论 的 信息 ， 表 结构 如 表 9-2 所 示 。 
表 9-2 表 微 博 评论 信息 表 


字段 类 型 属性 nu RA SO 
cid mediumint(8) EJ auto increment 
mid mediumint(8) 8 
nickname  char(15) utf8 general ci m 
message  char(70) utf8 general ci 8 
dateline — int(10) ES 
ipaddress char(15) utf8 general ci ES 
display — tinyint(1) ES 


G) 微 博 配置 信息 表 (wb_friend)， 用 来 保存 微 博 配置 的 信息 ， 表 结构 如 表 9-3 所 示 。 


Var 一 


表 9-3 ” 微 博 配 置信 息 表 


字段 类 型 整理 Et ”Null RU S 
fid mediumint(8) EJ auto increment 
ftype tinyint(1) Ei 
furi char(90) utf8 general ci 否 
fcode char(16) uff general ci E 
fupdate int(10) E 
friendavatar char(50) utf8 general ci Ed 
friendname — char(15) utf8 general ci E 
friendmsg char(140) ^ uff general ci E 
friendpic — char(50) uif general ci EJ 
friendtime — int(10) E 
friendorigin — char(10) utf8 general ci EJ 


9.32 ”数据 库 配置 信息 


当 用 户 创建 好 数据 库 后 ， 用 户 需要 编写 好 配置 信息 ， 供 其 他 程序 员 调用 或 者 使 用 ， 下 


面 通 过 一 段 代码 进行 讲解 ， 其 代码 如 下 : 


<?php 


$mysql host "localhost";// 数 据 库 服务 器 地 址 


$mysql user = "root";// 用 户 名 
$mysql pass = "1234";// 密 码 
$mysql dbname = "weibo";// 数 据 库 名 


"wb ";// 数 据 库 表 前 级 名 


$mysql prefix 
?> 


完成 了 数据 库 设计 ， 在 开发 的 过 程 中 ， 数 据 库 设计 还 是 十 分 简单 的 ， 但 是 字段 一 定 要 
符合 标准 ， 有 一 定 的 含义 ， 不 要 胡乱 命名 ， 这 样 会 给 开发 带 来 一 定 的 难度 。 


9.4 系统 配置 信息 
“2010 年 8 月 24 日， 小 而 


系统 配置 模块 在 Web 项 目 中 很 常见 ， 通 常 将 经 常 需要 的 内 容 编 写 在 配置 文件 中 ， 当 需 
要 时 直接 调用 即 可 ， 这 样 即 提高 了 开发 效率 ,也 实现 了 面向 对 象 。 此 模块 由 我 来 亲自 负责 ， 
经 过 努力 之 后 ， 我 很 快 就 完成 了 任务 。 


9.4.1 站 点 配置 信息 


在 这 个 微 博 系统 里 ， 站 点 信息 是 必须 存在 的 ， 如 系统 版 本 、 微 博 名 称 等 ， 下 面 通 过 一 
段 代 码 进行 讲解 ， 其 代码 (config_site php) 如 下 : 


(312 K EE z 
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«?php 

// 设 置 博客 

$blog config = array( 

"yersion" => 1.2,// 博 客 版 本 

"skin" => "default",// 调 用 皮肤 模板 

"uri short™” => false, 

"per blog" => 20, // 博 客 每 一 页 

"comment open" => 2,// 首 页 评论 打开 条 数 
"per comment" => 20, 

"nickname" => "莎莎 ",// 博 客 名 

"timezone" => "Asia/shanghai",// 时 区 
"sitename" => "莎莎 美 啦 ", / /博客 名 称 
"siteurl" => "http://127.0.0.1/web/09weibo", // 博 客 地 址 
"Siteintro" => "",/ 

"keywords" => "shasha, weibo", // 关 键 字 
"miibeian" => "", 

"description" => "", 

"tracking code" => "", 

"pic upload" -» " static/picture/", 
"avatar upload" => " static/avatar/"); 
ini set('date.timezone', 'Asia/Shanghai'); 
?> 


942 用户 信息 的 管理 


由 于 此 微 博 系统 是 单 用 户 的 微 博 ， 所 以 系统 并 没有 将 用 户 信息 放 入 数据 库 里 ， 而 是 通 
过 加 密 的 方式 ， 将 信息 放 入 PHP 文件 里 ， 代 码 如 下 : 

<?php 

// 博 客 管理 员 和 密码 

$admin config = array("username"-» 


"admin", "password"=>"f6fdffe48c908deb0f4c3bd36c032e72", "authcode"-»"dfdQ 
jCRdjh6LQfbM"); 
?» 


用 户 的 密码 需要 加 密 ， 要 通过 特殊 手段 处 理 ， 不 然 密 码 很 容易 泄露 ， 代 码 如 下 : 
<?php 

// 同 步 配 置 

$sync config = array 

("twitter"-»array ("username"-»"", 
"password"-»""), 

"sina"-»array ("username"-»"", 
"password"-»""),"digu"-»array ("username"-»"", 
"password"-»""),"99]11"-»array ("username"-»"", 
"password"-»"")); 

2> 


Mogae A 240, 3&, EB Xe 65 


开发 完了 系统 配置 信息 ， 包 括 站 点 配置 信息 、 用 户 信息 的 管理 ， 主 要 用 于 修改 站 点 配 
置 和 用 户 信息 的 管理 ， 在 以 往 的 开发 过 程 中 ， 因 为 没有 开发 站 点 配置 信息 、 用 户 信息 的 管 
理 ， 修 改 站 点 比较 麻烦 ， 所 以 这 次 吸取 经 验 ， 近 一 步 完善 了 网 站 。 总 结 完毕 后 ， 一 看 时 间 


v 
V 深入 体验 PHP 项 目 开发 


S pw. Rok KS. 


9.5 Bj & i& it 
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昨天 我 完成 了 系统 配置 文件 的 编码 工作 ， 至 此 整个 项 目的 前 期 准备 工作 圆满 完成 。 接 
下 来 将 进入 正式 的 设计 编码 工作 ， 为 了 使 时 间 更 加 合理 ， 我 划分 了 以 下 4 个 阶段 。 

O 首页 设计 

口 首页 配置 页 面 

Oo 评论 页 面 

Q ”网 页 关注 功能 


9.5.1 首页 设计 


在 系统 首页 里 ,向 浏览 者 展示 了 各 种 各 样 的 功能 ， 如 浏览 个 人 微 博 功 能 ， 如 图 9-3 所 示 
为 本 微 博 的 系统 首页 。 
和 Pa - Windows Interner Expiorer leic mci 
QU e ane BEI EET p- 
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图 9-3 系统 首页 
下 面 通过 一 段 代 码 进行 讲解 ， 其 代码 如 下 : 
«?php 
require once(dirname( FILE )."/global.php");// 调 用 页 面 
// 调 用 设置 
if( isset($ POST['MSG']) ) ( 


if( !$1oginStat ) 1 
$actionResult = "0"; } 


(314 « "———— ————————————— —  — 
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else { 
$msg con = filterCode($ POST['MSG'],$blog config['url short']); 
if( empty ($msg con) || getStrlen ($msg con) > 140 ) ($actionResult = "-2"; 
}// 
else( 


$pic url- (isset($ POST['PIC']) && file exists($blog config['pic upload']. 
S POSTI"PIC' T) 3 9 $:POSPI VPICUT 3 "m; 
$DB = database(); 
$updateRes = blogAction::blogUpdate($msg con, $pic Url, "Web") 7 
$DB-»close(); 
if( $updateRes ) {// 更 新 
$syncMsg = $ POST['MSG']; 
if( !empty($pic url) ) 
t 
$syncMsg .- " ".$blog config['siteurl']."/". 
$blog config['pic upload'].str replace("/s ","/b ",$pic url); 
} 
&syncUpdate ($syncMsg); 
$actionResult = "1"; 
} 
else 
$actionResult = "-1"; 
} }} 
if( isset($ POST['deleteId'],$ POST['deletePic']) ) { 
if( $loginstat ) i 
$DB = database (false); // 是 否 打开 数据 库 
$delRes = blogAction::delBlog($ POST['deleteId'], 
$ POST['deletePic']);// 删 除 图 片 
$DB-»close(); 
if( $delRes ) { 
$actionResult = "1"; 
} }} 
// 从 数据 库 中 调 入 信息 
if( isset($actionResult) { 
echo $actionResult; } 
else( 
$getPage - (isset($ GET['p']) && is numeric($ GET['p']) && $ GET['p'] 
» 1) ? intval($ GET['p']) : 1; 
$DB = database(); 
$blogArr = BlogAction::getBlog($getPage,$blog config['per blog']);// 
博客 活动 
$blogDay = BlogAction::getStat ( (time ()-86400) );// 博 客 日 期 
$blogWeek = BlogAction::getStat ( (time ()-604800) ) ;// 博 客 周 期 
$DB-»close () ;// 关 闭 页 面 
$pageArr = pageAction::blogPage ($blogArr['Total'], 
$blog config['per blog'],$getPage); 
$tmp = template ("index.html"); //i]A ÑH 
$tmp-»assign( 'blogConfig', $blog config ) 7;// 博 客 配置 
$tmp-»assign( 'loginStat', $loginStat );// 登 录 启用 
$tmp-»assign( 'thisPage', $getPage );// 获 取 页 面 
$tmp-»assign( 'blogArr', $blogArr );// 博 客 
$tmp-»assign( 'blogDay', $blogDay );// 博 客 日 期 
$tmp-»assign( 'blogWeek', $blogWeek ) ;// 博 客 周期 
$tmp-»assign( 'pageArr', $pageArr ); 
$tmp-»output (); ) 
ob end flush(); 
?» 


àd 
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9.52 ”首页 配置 页 面 


在 首页 里 ， 除 了 让 用 户 看 到 的 日 志和 评论 外 ， 还 需要 调 入 一 些 配置 信息 ， 如 博客 名 称 、 
博客 地 址 等 一 系列 信息 ， 下 面 通 过 一 段 代码 进行 讲解 ， 其 代码 (global.php) 如 下 : 


«?php 
require once(dirname( FILE )."/global.php");// 调 入 页 面 
if( isset($ POST['MSG']) ) {// 调 入 配置 
// 判 断 情况 
if( !$1oginstat ) { 
SactionResult = "0"; 


um { 
// 检 查 博客 配置 
$msg con = filterCode($ POST['MSG'],$blog config['url short']); 
if( empty ($msg con) || getStrlen($msg con) > 140 ) fi 
$actionResult = "-2"; 
E { 
// 检 查 文件 


$pic url = (isset($ POST['PIC']) && 
file exists($blog config['pic upload'].$ POST['PIC'])) ? $ POST['PIC'] 
"n. 

$DB = database(); 

$updateRes = 

blogAction::blogUpdate($msg con,$pic url, "Web"); 

S$DB-»close(); 

if( $updateRes ) // 更 新 配置 


$syncMsg = $ POST['MSG']; 
if( !empty($pic url) ) 
{ 


$syncMsg .= " ".$blog config['siteurl']."/".$blog config 
['pic upload'].str replace("/s ","/b ",$pic url); 
) 


&syncUpdate ($syncMsg) ; 
$actionResult = "1"; 

} 

else 
$actionResult - "-1"; 


) 
5 
// 配 置 文件 
if( isset($ POST['deleteId'],$ POST['deletePic']) ) ( 
if( $loginstat ) { 
$DB = database (false); 
$delRes = 
blogAction::delBlog($ POST['deleteId'],$ POST['deletePic']); 
SDB-»close(); 
if( $delRes ) { 
$actionResult = "1"; 
) 
P 
if( isset($actionResult) ) { 
echo $actionResult; } 
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else( 


$getPage = (isset($ GET['p']) && is numeric($ GET['p']) && $ GET['p'] 


21) 9? 3ntyatts GET pi) i; 
$DB = database(); 
$blogArr = BlogAction::getBlog($getPage,$blog config['per blog']); 
$blogDay = BlogAction::getStat ((time()-86400));//18 A Hi HH 
$blogWeek = BlogAction::getstat((time()-604800));// 博 客 活动 
$DB-»close(); 
$pageArr = pageAction::blogPage 

(SblogArr['Total'],$blog config['per blog'],$getPage); 

$tmp = template ("index.html");// 调 用 模板 信息 
$tmp-»assign( 'blogConfig', $blog config ) ;// 博 客 配置 
$tmp-»assign( 'loginstat', $1oginstat );// 登 录 配置 
$tmp-»assign( 'thisPage', $getPage );// 调 用 页 面 
$tmp-»assign( 'blogArr', $blogArr );// 博 客 地 址 
$tmp-»assign( 'blogDay', $blogDay );// 博 客 日 期 
$tmp-»assign( 'blogWeek', $blogWeek );// 博 客运 行 周期 
$tmp-»assign( 'pageArr', $pageArr );// 页 面 地 址 
$tmp->output ();} 

ob end flush(); 

?» 


9.5.3 评论 页 面 


当主 人 发 表 一 篇 微 博文 时 ， 浏 览 者 可 以 对 其 发 表 评 论 ， 实 现 与 浏览 者 交互 的 功能 。 如 


图 9-4 所 示 的 是 微 博 评 论 页 面 。 
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图 9-4 微 博 评论 页 面 
下 面 通过 一 段 代 码 进行 讲解 ， 其 代码 如 下 : 
«?php 
require once(dirname( FILE )."/global.php");// 调 入 页 面 
// 判 断 博客 
if( isset($ POST['mid'],$ POST['nickname'],$ POST['comment']) ) ( 
if( $blog config['comment open'] == "0" ) { 


$error info = "0 禁止 评论 ";// 评 论 字符 为 零 不 允许 评论 


else i 


àd 
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if( $loginstat ) { 
$nickname = "";//WEfk 
$ipAddress = "";//IP 地 址 
$display = 1; 


H 
else { 
// 判 断 昵 称 
$nickname = trim($ POST['nickname']); 
if( !empty($nickname) ) t 
$checkName = checkName ($nickname); 
if( !empty($checkName) ) t 
$error info = "-1 ".$checkName; 
} } 
$ipAddress = getClientIP(); 


$display = ( $blog config['comment open'] == "1" ) ? 1 : 0; 
} } 
if( isset($error info) ) i 
echo $error info; 
Jelse ( 
$msg con = filterCode($ POST['comment'],$blog config['url short']); 
// 评 论 字符 限制 


if( empty ($msg con) || getStrlen($msg con) > 70 ) 
t 
echo "0 评论 不 能 为 空 且 不 超过 70 个 字符 "> 
)else( 
$DB = database(); 
$blogId = $DB-»fetch one ("SELECT 'mid' FROM '".$mysql prefix."blog' WHERE 
'mid'-'".$ POST['mid']."'"); 
// 如 果 评 论 为 字符 零 ， 提 示 用 户 
if( empty($blogId) ) 


( echo "0 评论 被 拒绝 "; } 
else { 
// 字 符 超出 提醒 用 户 
if( blogAction::commentUpdate ($blogId, $nickname, $msg con, $ipAddress, 
$display) ) { 
if( $display ) { 


$commentNum = $DB->fetch one("SELECT COUNT('cid') 
FROM '".$mysql prefix."comment' WHERE 'mid'-".$blogId); 
$lastPage = 
ceil($commentNum/$blog config['per comment']); 
echo "1 ".$1astPage; 
} 
else 
echo "2 评论 成 功 审核 后 可 见 "; 
} else echo "0 评论 失败 "; 
) 
SDB-»close(); 
unset ($DB) ; 


b }} 
if( isset($ POST['messageId'],$ POST['deleteId']) ) { 


if( $loginstat ) { 
$DB = database(false); // 是 否 打 开 数 据 库 


if( blogAction::delComment($ POST['messageId'],$ POST['deleteId']) ) 
t echo "1"; ) 
SDB-»close(); 
unset ($DB) ; 
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}} 
if( isset($ POST['displayId']) ) { 
if( $loginStat ) { 
$DB = database (false); 
if ( $DB->query ($DB->update sql("'".$mysql prefix."comment'", array ("display"=>1), 
"eld = $ POST['displayId"]-"*")).) 
{ 
echo "1"; T 
SDB-»close(); 
unset ($DB) ; 
} 
} 
if( isset($ POST['id'],$ POST['pg"]) ) í 
$msgId = intval($ POST['id']);// 信 息 标 识 
$pgNum = intval($_POST['pg']);// 页 面 编码 
$DB = database(); 
$commentArr = blogAction::getComment 
($msgId,$pgNum,$blog config['per comment']); 
$DB-»close(); 
unset ($DB) ; 
// 分 配 配置 信息 
$pageArr = pageAction::commentPage 
($msgId,$commentArr['Total'],$blog config['per comment'],S$pgNum); 
$tmp = template ("comment .html") ;// 注 释 页 面 
$tmp-»assign( 'blogConfig', $blog config ) ;// 博 客 配置 
$tmp-»assign( 'loginStat', $loginstat );// 登 录 启 动 
$tmp-»assign( 'messageId', $msgId );// 分 配 消息 
$tmp-»assign( 'commentArr', $commentArr );// 评 论 
$tmp-»assign( 'pageArr', $pageArr ); 
$tmp-»output (); 
unset ($tmp); ) 
ob end flush(); 
?» 


9.5.4 网 页 关注 功能 


微 博 最 大 的 功能 就 是 知道 被 关注 的 程度 ， 你 的 好 友 可 以 将 您 设置 为 “关注 ”， 您 更 新 
微 博 后 ， 将 第 一 时 间 通 知 您 的 好 友 ， 您 已 经 更 新 ， 如 图 9-5 所 示 。 
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图 9-5 关注 功能 页 面 
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下 面 通过 一 段 代码 进行 讲解 ， 其 代码 (follow.php) 如 下 : 


«?php 

require once(dirname( FILE )."/global.php");// 调 用 页 面 

// 关 注 功 能 

$getPage = (isset($ GET['p']) && is numeric($ GET['p']) && $ GET['p'] >1) ? 
intval($ GET['p']) : 1;// 获 得 页 面 

$friendType = (isset($ GET['t']) && $ GET['t'] == "fans") ? 2 : 1;// 朋 友 页 面 
$DB = database () ;// 打 开 数 据 库 

$friendArr = BlogAction::getFriend("'ftype'-".$friendType." AND 'fupdate"' 
> // 友 情 访 问 

". (time()-3600),"'friendtime'",S$getPage,20); 

$DB-»close() ; // 关 闭 数据 库 

unset ($DB) ; 

// 分 配 配置 信息 

$pageArr = pageAction::blogPage ($friendArr['Total'],20,$getPage); 

$tmp = template ("follow.html"); 

$tmp-»assign( 'blogConfig', $blog config );// 博 客 配置 

$tmp-»assign( 'loginstat', $loginstat ); 

$tmp-»assign( 'friendType', $friendType ); 

$tmp-»assign( 'friendArr', $friendArr ); 

$tmp-»assign( 'pageArr', $pageArr ); 

$tmp-»output (); 

unset ($tmp) ; 

ob end flush(); 

?> 
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今天 我 完成 了 前 台 模块 的 设计 工作 。 我 觉得 对 于 微 博 系统 来 说 ,前 台 涉及 了 首页 设计 、 
配置 页 面 、 评 论 页 面 和 网 页 关注 功能 ， 这 些 都 是 微 博 的 常用 功能 。 微 博 是 博客 过 后 的 又 一 
网 络 工具 ， 起 初 不 了 解 其 特点 ， 走 了 很 多 弯路 ， 经 过 两 天 两 夜 深 入 研究 ， 重 新 定义 了 方向 
让 自己 设计 的 微 博 更 加 适用 。 


96 建立 各 种 各 样 的 类 
| 200389289, 两， 老 同学 的 任务 


今天 我 将 前 面 所 有 的 资料 都 交 给 了 同事 C, 接 下 来 将 由 他 来 完成 类 模块 编码 工作 。 因 为 
此 模块 的 很 重要 且 都 是 基于 PHP 编程 的 ， 所 以 在 成 立 团队 之 初 就 决定 让 新 来 的 老 同学 同事 
C 来 完成 。 这 样 一 来 可 以 使 他 快速 适应 开发 节奏 ， 二 来 可 以 向 公司 展现 他 的 开发 实力 。 


9.6.1 分 页 功能 


随 着 使 用 时 间 的 增加 ， 微 博信 息 肯 定 要 进行 分 页 ， 不 然 将 很 难 管理 整个 系统 的 页 面 ， 
下 面 的 这 段 代 码 能 实现 上 述 功能 ， 其 代码 (class Pagephp) 如 下 : 


«?php 
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class pageAction 


{ 
// 定 义 微型 博客 页 码 
function blogPage ($total, $per, $page) 
t 
$pagePre = "";// 页 面 配置 
$pageFirst = ""; 页 面 第 一 条 信息 
$pageList = "";// 页 面 列表 
$pageLast = "";// 页 面 最 后 一 条 信息 
$pageNext = "";// 下 一 条 记录 
$allpage = ceil($total/$per);// 全 部 信息 
$startcount = $page - 3;// 自 动 编号 
$endcount = $page + 3; 
if( $startcount « 1 ) 
t 


[j 


$startcount = 1; 
} 
if( $allpage < $endcount ) 
t 
$endcount = $allpage; 
} 
$string = str replace("index.php","",$ SERVER['PHP SELF'])."?"; 
foreach( $ GET as $k => $v ) 
t 
LE Sk pr y 
t 
$string .= "".$k."-".urlencode($v)."&"; 
} 
} 
if( $allpage > 1 ) 
t 
if( $page > 1 ) 
t 
$pagePre = '«a href-"'.$string.'p-'.($page-1).'" 
title=" L— Ji"»&1t;&lt;«/a»'; 
) 
if( $page > 5 ) 
t 
$pageFirst = '«a href-"'.$string.'p-1" 
title=" 首 页 ">1...</a>'; 


) 

for( $i = $startcount; $i <= $endcount; $i++ ) 

t 

$pageList .= ($page == $i) ? '«strong»'.$i.'«/strong»' 
'«a href-"'.$string.'p-'.$1.'"2'.$i.'«/a»'; 

) 

if( $page < ($allpage-4) ) 

t 


$pageLast = '«a href-"'.$string.'p-'.$allpage.'" 
title-"REJi"»...'.$allpage.'«/a»'; 
H 
if( $page < $allpage 
t 
$pageNext = '«a href-"'.$string.'p-'.($page41).'" 
title=" F—Ji"»&gt;&gt;«/a»'; 
} 


} 
// 返 回 的 页 码 


bad 
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Sreturn['pageTotal'] = $allpage; 
$return['pagePre'] = $pagePre; 
$return['pageFirst'] = $pageFirst; 


$return['pageList'] = $pageList; 
$return['pageLast'] = $pageLast; 
$return['pageNext'] = $pageNext; 
return $return; 
$ 
function commentPage ($id, $total, $per, $page) 
t 
$pageTotal = ceil($total/$per); 
$pagePre = ""; 
$pageNext = ""; 
if( $pageTotal » 1 ) 
t 
if( $page > 1 ) 
t 
$pagePre = 
"<a href-"javascript:;" onclick-"getComments ('.$id.','.($page-1).',1);"» 
上 一 页 </a>&nbsp; &nbsp; ' ; 
} 
if( $page < $pageTotal ) 
{ 


$pageNext = '&nbsp;&nbsp;«a href-"javascript:;" 
onclick-"getComments ('.$id.','. ($page*1) .',1);"> 下 一 页 </a>'; 
) 
} 
$pageArr = array( "pageTotal" => $pageTotal, "pagePre" = 
> $pagePre, "pageNext" => $pageNext ); 
return $pageArr; 
) 
function mobilePage ($total,S$per,$page) 
t 
$string = $ SERVER['PHP SELF']."?"; 
foreach( $ GET as $k => $v ) 
{ 
iE Sk tS Ppr) 
{ 
$string .= "".$k."=".urlencode ($v) ."&amp;"; 
ih 
) 
$pageTotal = ceil($total/$per); 
$pagePre - ""; 
$pageNext = ""; 
if( $pageTotal > 1 ) 


t 
if( $page > 1 ) 
t 
$pagePre = '«a href-"'.$string.'p-'.($page-1).'"» 
depen 
H 
if( $page < S$pageTotal ) 
t 
$pageNext = '«a href-"'.$string.'p-'.($page41).'"» 
Ra 
lj 
} 


$pageArr = array( "pageTotal" => $pageTotal, "pagePre" => $pagePre, 
"pageNext" => $pageNext ); 
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return $pageArr; 


9.6.2 ”数据 库 编程 


数据 库 是 系统 的 核心 ， 任 何 一 个 信息 数据 库 都 离 不 开 数 据 库 编程 ， 微 博 系统 也 不 例外 ， 
下 面 通过 一 段 代 码 进行 讲解 ， 其 代码 (class_Mysql.php) 如 下 : 
«?php 
// 定 义 一 个 数据 库 类 
class DB MySQL ( 
var $querycount - 0; 
// 返 回 错误 的 信息 
function error() ( 
return mysql_error () ; // 返 回 数据 库 错误 信息 
) 
function geterrno() ( 
return mysql errno(); 


) 
// 返 回 ia € 
function insert id() ( 
$id = mysql insert id(); 
return $id; 


) 
// 连 接 
function connect ($servername, $dbusername, $dbpassword, $dbname, 
$usepconnect=0) { 
if($usepconnect) { 
if (!@mysql pconnect ($servername, $dbusername, $dbpassword)) 


die("Could not Connect"); 
} 
} else { 
if (!@mysql connect ($servername, $dbusername, $dbpassword)) 


die("Could not Connect @ ".$this->geterrno()); 
) 
H 
mysql select db (S$dbname); 


) 
// 选 择 数据 

function select db($dbname) (// 
return mysql select db ($dbname) ; // 返 回 选择 数据 

} 

function query($sql,$type = '') { 
$query = mysql query ($sql); 
if(!$query && $type != 'SILENT') ( 

die('MySQL Query Error: '.$sgl); 

} 
$this->querycount++; 
return $query; 


H 
// 受 到 限制 的 行 


function affected rows ($sql) 


———————————————————————————————— >B 
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t 
Sthis-»query ($sql); 
return mysql affected rows():; 


} 
// 返 回 数组 
function fetch array($query) ( 
return mysql fetch array ($query); 


) 
// 获 取 的 记录 

function fetch row($query) ( 
$query = mysql fetch row ($query); 
return $query; 

} 

function fetch one array ($query) { 
$result = $this-»query ($query) ; 
$record = $this->fetch array ($result); 
return $record; 


// 返 回 搜索 的 一 条 

function fetch one($query) ( 

$record = $this-»fetch one array ($query); 
Return $record[0]; 


// 返 回 行 

function num rows ($query) ( 

$query = mysql num rows ($query) ; 
return $query; 


// 返 回 自 由 的 结果 

function free result ($query) ( 

$query = mysql free result ($query); 
return $query; 


function close() ( 
return mysql close(); 


// 描 述 对 象 
function version() ( 
return mysql get server info(); 


function fetch all($sql) ( 

Sarr = array(); 

$query = Sthis-»query ($sq1); 

while($data = $this->fetch array ($query)) { 
$arr[] = $data; 

} 

return $arr; 


} 
// 收 集 插入 的 数据 
function compile db insert string($data) 
i 
$field names = ""; 
$field values = ""; 
foreach ($data as $k => $v) 
{ 
$field names .- "$k,"; 
$field values .= "'$v',"; 
) 
$field names = preg replace( "/,$/" , "" , $field names ); 
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$field values = preg replace( "/,$/" , "" , $field values ); 
return array('FIELD NAMES' => $field names, 

'FIELD VALUES' => $field values, 

); 


) 
// 收 集 更 新 的 数据 
function compile db update string ($data) 
t 
$return string - ""; 
foreach ($data as $k => $v) 


t 
if(is array($v)) 
t 
$return string -= Sk w=n Sy porq. 
}else 
i 
$return string .- $k . "-'".$v."',"; 
) 


) 
$return string = preg replace( "/,$/" , "" , $return string ); 
return $return string; 


jj 
// 插 入 数据 
function insert sql( $tbl , $arr ) 
it 
$dba $this-»compile db insert string( $arr ); 
$sql "INSERT INTO {$tbl} ({$dba['FIELD NAMES']}) VALUES 
({$dba['FIELD VALUES']))"; 
return $sql; 


} 
// 更 新 数据 
function update sql($tbl , $arr , $where-'') 
t 
$dba = $this-»compile db update string( $arr ); 
$query - "UPDATE ($tbl) SET $dba"; 
if ( $where ) 
t 
$query .= " WHERE ".$where; 
) 
return $query; 
) 


9.6.3 mD RE 


为 了 让 微 博 实现 强大 的 功能 ， 必 须 建立 相关 的 类 ， 使 功能 面向 对 象 ， 这 样 将 便于 系统 
维护 。 下 面 通过 一 段 代 码 进行 讲解 ， 其 代码 (class_blog.php) 如 下 : 

«?php 

// 建 立 博客 类 

class blogAction 


t 
// 更 新 
function blogUpdate ($message, $picture, $origin) 
t 
global $DB,$mysql prefix,$blog config; 
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$arr = array("message"-»$message, "picture"-»$picture, "dateline"-»time(), 
"origin"-»$origin, "comments"-50); 

// 判 断 数据 库 表 的 前 绥 
if( $DB-»query($DB-»insert sql("'".$mysql prefix."blog'",$arr)) ) 

t 


return true; 
) 
else 
t 
return false; 
} 
} 
// 评 论 更 新 
function commentUpdate ($mid, $name, $msg, $ip, $display=1) { 
global $DB,$mysql prefix; 
$arr = 
array ("mid"=>$mid, "nickname"-»$name, "message"-»$msg, "dateline"-»time(), 
"ipaddress"-»$ip, "display"-»$display); 
// 判 断 插 入 


if( $DB-»query( $DB-»insert sql("'".$mysql prefix."comment'",$arr) ) ) 
t $DB-»query( $DB-»update sql("'".$mysql prefix."blog'",array 
("comments"-»array("'comments'41")),"'mid'-".$mid) ); 
return true; 
) 
else 
t 
return false; 
t 


} 
// 删 除 微 博 记 录 

function delBlog ($mid, $pic) 

{ 
global $DB,$mysql prefix; 
$DB->query ("DELETE FROM '".$mysql prefix."blog'WHERE 'mid 
SDB-»query ("DELETE FROM ' ".$mysql prefix."comment'WHERE 'mid' 
delPicture($pic); 
return true; 


.$mid."'"); 
mld. mm 


} 
// 删 除 评论 
function delComment ($mid, $cid) 
t 
global $DB,$mysql prefix; 
$delNum = $DB-»affected rows ("DELETE FROM '".$mysql prefix."comment' WHERE 
'mid'-'".$mid."' AND 'cid'-'".$cid."'"); 
if( $delNum > 0 ) 
t 
$DB-»query( $DB-»update sql("'".$mysql prefix."blog'",array 
("comments"-»array ("'comments'-1")),"'mid'-'".$mid."'") ); 
H 
return true; 


) 
// 写 入 微 博 博文 数据 
function getBlog ($page, $per) 
t 
global $DB,$mysql prefix; 
$blogArr = array(); 
$Total = SDB-»fetch one ("SELECT COUNT ('mid') FROM 
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'".$mysql prefix."blog'"); 
// 根 据 博文 分 页 
if( $Total > 0 ) 
t 
$lastPage = ceil($Total/$per); 
if( $page > $1lastPage ) 
t 
$page = $lastPage; 
} 
$Result = $DB->query ("SELECT * FROM '".$mysql prefix."blog' ORDER BY "mid'" 
DESC LIMIT ".($page-1) *$per.",".$per); 
while($Re = $DB-»fetch array ($Result)) 


t 
$blogArr[] = array( 
"mid" => SRe['mid'], 
"message" => filterHTML ($Re['message']), 
"picture" => $Re['picture'], 
"piclink" => 


str replace("/s ","/b ",$Re['picture']), 
"dateline" => SRe['dateline'], 
"origin"-» stripslashes ($Re['origin']), 
"comments" => $Re['comments'] 
); 
} 

} 

$return['Total'] = $Total; 

$return['Blog'] = $blogArr; 

return $return; 


} 
// 写 入 评论 
function getComment ($mid, $page, $per) 
t 
global $DB,$mysql prefix; 
$commentArr = array(); 
$Total = $DB-»fetch one ("SELECT COUNT('cid') FROM 
'".$mysql prefix."comment' WHERE 'mid'-".$mid); 
7/ 判断 评论 ， 让 评论 生成 页 面 
if( $Total > 0 ) 
t 
$lastPage = ceil($Total/$per); 
if( $page > $lastPage ) 
t 
$page = $lastPage; 
} 
$Rs = $DB->query ("SELECT * FROM '".$mysql prefix."comment' WHERE 
'mid'-".$mid." ORDER BY 'cid' ASC LIMIT ".($page-1)*$per.",".$per); 
while (SRe = $DB-»fetch array ($Rs)) 
t 
S$commentArr[] = array( 


foras => $Re['cid'], 
"mid" => $Re['mid'], 
"nickname" => stripslashes ($Re['nickname']), 


"message" => filterHTML ($Re['message']), 
"dateline" => $Re['dateline'], 
"ipaddress" => $Re['ipaddress'], 

"display" => $Re['display'] 

); 
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Sreturn['Total'] = $Total; 
$return['Comment'] = $commentArr; 
return $return; 
} 
function getStat ($time) // 获 取 时 间 
t 
global $DB,$mysql prefix; 
return $DB-»fetch one ("SELECT COUNT('mid') FROM '".$mysql prefix."blog' 
WHERE 'dateline' > ".$time); 
) 
function getFriend($where, $order, $page, $per) // 获 取 友 情 链接 
t 
global $DB,$mysql prefix; 
SfriendArr = array(); 
$Total = $DB-»fetch one ("SELECT COUNT('fid') FROM '".$mysql prefix."friend" 
WHERE ".$where); 
if( $Total » 0 ) 
t 
$lastPage = ceil($Total/$per); 
if( $page > $lastPage ) 
t 


$page = $lastPage; 


} 
$Result = $DB->query ("SELECT * FROM '".$mysql prefix."friend' WHERE 
".$where." ORDER BY ".$order." 
DESC LIMIT ".($page-1) *$per.",".$per); 
while($Re = $DB-»fetch array ($Result)) 
t 
$friendArr[] = array( 


Deae hd => $SRe['fid'], 
"fari" => $Re['furl'], 
"fupdate" => $Re['fupdate'], 


"friendavatar" => 
urlencode (base64 encode ($Re['furl']."]]||".$Re['friendavatar'])), 


"friendname" => 
stripslashes ($Re['friendname']), 
"friendmsg" => 
filterHTML ($Re['friendmsg']), 
"friendpic" => empty($Re['friendpic']) ? "" : 
SRe['furl'].$Re['friendpic'], 
"friendpid" => empty($Re['friendpic']) ? "" 
urlencode (base64 encode ($Re['furl'].$Re['friendpic'])), 
"friendtime" => SRe['friendtime'], 


"friendorigin" => 
stripslashes ($Re['friendorigin']) 
); 
} } 
Sreturn['Total'] = $Total; 
$return['Friend'] = $friendArr; 
return $return; 


今天 ， 老 同学 同事 C 完成 了 各 个 重要 类 的 编码 工作 。 这 些 类 都 是 基于 数据 库 的 ， 数 据 
库 中 有 很 多 基本 功能 的 开发 ， 例 如 常用 的 分 页 功能 、 数 据 库 编 程 和 微 博 的 博文 展示 功能 ， 
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这 些 功能 各 自 实际 上 都 很 简单 ， 但 是 要 将 这 些 功 能 融合 和 加 工 ， 就 有 一 定 的 难度 。 我 在 开 
发 的 过 程 中 ， 也 经 过 了 很 长 的 时 间 地 思考 。 


9.7 后 台 管 理 


刚刚 完成 类 模块 的 编码 工作 ， 同 事 C 又 马上 开始 了 后 台 管 理 模块 的 开发 工作 。 此 模块 
和 其 他 系统 的 后 台 模 块 一 样 ， 都 是 基于 数据 库 并 实现 对 数据 库 数据 管理 的 。 


9.7.1 后 台 登 录 页 


要 进入 系统 进行 管理 ， 需 要 设计 一 个 登录 页 ， 和 凭借 自己 的 用 户 名 和 密码 进入 系统 ， 并 
管理 整个 系统 ， 如 图 9-6 所 示 为 后 台 登 录 页 。 
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图 9-6 后 台 登 录 页 
下 面 通过 一 段 代码 进行 讲解 ， 其 代码 (login.php) 如 下 : 


«?php 
require once(dirname( FILE )."/global.php"); 
if( isset($ GET['do']) && $ GET['do'] == "logout" ) 


t 
loginout () ;// 退 出 
header ("location: ./") ;// 头 部 信息 
} 
else 
t 
if( $1oginStat ) 
{ 
header ("location:./"); 
$ 
else 
t 
$loginResult - ""; 
if( isset($ POST['username'],$ POST['password']) ) 


——————————————————————— —— RT > 
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t 
// 判 断 用 户 信息 
$username = filterCode($ POST['username']); 
$password = filterCode($ POST['password']); 
if( loginCheck ($username, $password) ) 
$1oginResult = "ok"; 
else 
$loginResult = "error"; } 
// 加 载 配置 


$tmp = template ("login.html"); 
$tmp-»assign( 'blogConfig', $blog config );/ 
$tmp-»assign( 'loginResult', $loginResult ); 
$tmp-»output () ; 

}} 


ob end flush(); 


?> 


97.2 ”账户 管理 


在 同一 微 博 内 允许 多 位 用 户 进行 管理 ， 在 后 台 可 以 设置 新 的 用 户 名 和 密码 ， 也 可 以 修 
改 密码 ， 如 图 9-7 所 示 为 后 台 登 录 页 。 
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图 9-7 账户 管理 


下 面 通过 一 段 代码 进行 讲解 ， 其 代码 (password.php) 如 下 : 


<?php 
require once (dirname( FILE )."/global.php");// 调 入 页 面 
// 设 置 新 用 户 名 和 密码 


if( 


t 


isset($ POST['username'],$ POST['password'],$ POST['newusername'],$ 
POST['newpassword']) ) 


if( !$1oginStat ) 
{ 
echo "0"; 


else 
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$curusername = filterCode ($ POST['username']);// 用 户 名 

$curpassword = filterCode($ POST['password']) ;// 密 码 

$newusername = filterCode($ POST['newusername']);// 新 用 户 名 

$newpassword = filterCode($ POST['newpassword']);// 新 密码 

if( $curusername != $admin config['username'] || 
md5($curpassword) != $admin config['password'] ) 

t 

$errorInfo = "当前 用 户 名 与 密码 不 匹配 "; 


} 
else 
t 
if( empty($newusername) && empty($newpassword) ) 
t 
$errorInfo = "您 需要 修改 什么 ? "; 
} 
else 
t 
if( empty($newusername) ) // 判 断 用 户 名 和 新 用 户 名 是 否 相 同 
{ 
$newusername = $admin config['username']; 
) 
if( strlen($newusername) < 3 )// 判 断 字 符 长 途 
{ 
$errorInfo = "新 用 户 名 至 少 3 个 字符 "; 
) 
else 
t 
if( empty($newpassword) ) 
t 
$newpassword = $admin config['password'];// 对 比 密码 
是 否 相 同 
} 
else 
{ 
if( strlen($newpassword) < 6 )// 判 断 密码 长 度 
{ 
$errorInfo = "新 密码 至 少 6 W"; 
) 
else 
{ 
$newpassword = md5 (Snewpassword) ;// 密 码 加 密 
) 
) 
) 
) 
) 
if( isset(S$errorInfo) && !empty($errorInfo) ) // 错 误 信息 
t 
echo SerrorInfo; 
} 
else 
{ 


$config str = '$admin config = array ("username" 
-»"'.$newusername.'","password"-»"'.$newpassword.'","authcode"-»"' 
createSecureKey()-'")z"'; 

SupdateFile = updatePhpFile ("database/config admin.php",$config str); 

if( SupdateFile == "" ) 


———— —————————————————— ———— M » 
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t 
echo "1"; 
) 
else 
t 
echo S$updateFile; 
) 
) 
l 
5 
else 
t 
if( !$1oginstat ) 
t 
header ("location: ./1login.php");// 调 入 头 部 信息 
} else { 
$tmp = template ("password.html");// 调 入 页 面 信息 
$tmp-»assign( 'blogConfig', $blog config );// 博 客 配置 
$tmp-»assign( 'adminConfig', $admin config );// 管 理 页 面 配置 
$tmp-»assign( 'loginStat', $1oginstat );// 登 录 启动 
$tmp->output (); 
} 
} 
ob end flush(); 
?» 


9.7.3 微 博 设置 


在 前 面 曾经 讲解 过 用 一 个 专门 页 面 来 保存 配置 信息 。 在 这 里 再 讲解 一 个 可 以 修改 整个 
微 博 配 置信 息 的 页 面 ， 如 图 9-8 所 示 。 
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图 9-8 微 博 设 置 页 面 
下 面 通过 一 段 代 码 进行 讲解 ， 其 代码 (setting .php) 如 下 : 


<?php 
require once(dirname( FILE )."/global.php");// 调 入 页 面 
// 判 断 信息 


[ 332 | 人 ————— ———————— 
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if( isset($ POST['version'],$blog config['version']) && $ POST['version'] 
== $blog config['version'] ) 


t 


if( !$1oginsStat ) 


t 


echo "0"; 


) 
else 
d 


$config str = '$blog config = array('; 
foreach( $ POST as $key => $val ) 


t 


if( isset($blog config[$keyl) )// 博 客 配置 


t 


if( $key == "nickname" ) 

t 
$error info = checkName ($val); 
if( !empty(Serror info) ) 


t 
break; 
) 
) 
if( $key == "siteurl" ) 
t 
if(substr($val,0,7) != "http://" | | substr($val,-1) = "/") 
t 
$error info =" 微 博 地 址 请 以 http:// 开头 , 结尾 不 要 加 /"; 
break; 
} 
} 
if( $key == "siteintro" ) 
{ 
$val = strAddslashes (trim($val)); 
} 
else if( $key == "tracking code" ) 
{ 
$val = 
str_replace (array ("\r","\n"),"",strAddslashes (trim($val))); 
} 
else 
t 
$val = filterCode (htmlspecialchars ($val)); 
y 
if( is numeric ($val) || $val == "true" || $val == "false" ) 
t 
$Scontigostr = "Aona koy- "yt => n Syal." 
} 
else 


H 


) 


$config str .— "XnX"".$key."V" => N"".$yal."N","; 


/* 删除 最 后 部 分 */ 
$dh = opendir(" cache/"); 
while( $file = readdir($dh) ) 


t 


if( substr($file,-9) == " html.php" ) 


{ 


unlink(" cache/".$file); 


4 
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) 
closedir($dh); 
/* 最 后 部 分 隐藏 */ 
// 判 断 配 置信 息 是 否 符合 要 求 
if( isset(Serror info) && !empty(Serror info) ) 
t 
echo $error info; 
) 
else 
i 
$config str = substr($config str,0,-1)."); An"; 
if( !empty($ POST['timezone']) ) 
t 
$config str .= 
'ini set (\'date.timezone\',\''.$ POST['timezone'].'V');'; 
} 
SupdateFile = 
updatePhpFile("database/config site.php",$config str); 
if( $updateFile == "" ) 
t 
echo "1"; 
) 
else 
t 
echo $updateFile; 
) 


) 
else 
t 
if( !$1oginsStat ) 
t 
header ("location:./login.php"); 
) 
else 
t 
$skinArr = array(); 
$source - "./ template/"; 
$handle = opendir($source); 
while( ($file = readdir($handle)) !-- false ) 
t 
if( $file != "." && $file != ".." ) 
t 
if( is dir($source.DIRECTORY SEPARATOR.$file) ) 
t 
$skinArr[] = array( "skin" => $file ); 
H 
) } 
// 分 配 信息 
closedir ($handle); 
$tmp = template ("setting.html"); 
$tmp-»assign( 'blogConfig', $blog config ); 
$tmp-»assign( 'trackingCode', htmlspecialchars (stripslashes 
($blog config['tracking code'])) ); 
$tmp-»assign( 'loginStat', $loginStat ); 
$tmp-»assign( 'skinArr', $skinArr ); 
$tmp-»output () ; 
H 
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ob end flush(); 
?» 


974 同步 更 新 


同步 更 新 功能 是 微 博 的 一 个 重要 功能 ， 它 是 同时 更 新 多 个 不 同 网 站 的 微 博 ， 如 图 9-9 
所 示 为 同步 更 新 的 功能 。 
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图 9-9 同步 更 新 的 功能 


下 面 通过 一 段 代码 进行 讲解 ， 其 代码 (sync.php) 如 下 : 


<?php 
require once(dirname( FILE )."/global.php"); 
if( isset($ POST['save']) ) 


{ 
if( !$1oginStat ) 
t 
echo "0"; 
) 
else 
t 


unset ($ POST['save']); 

$config str = '$sync config = array('; 
foreach( $_POST as $key => $arr ) // 搜 索 
{ 


$config str .= '"'.$key.'"-»array('; 
foreach( $arr as $k => $v ) 
t 


$config str .= '"'.$k.'"—»"'.strAddslashes (strip tags ($v)).'",'; 
H 
$config str = substr($config str,0,-1).'),'; 
) 
$config str — substr($config/str,0,-1)-*yz"; 
SupdateFile = updatePhpFile("database/config sync.php",$config str); 
if( SupdateFile == "" ) 
t 
echo "保存 成 功 "; 
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l 
else 
t 
echo $updateFile; 
i 
) 
F 
else 
t 
if( !$1oginsStat ) 
1 
header ("location:./login.php"); 
} 
else 
il 
$tmp = template ("sync.html");//B t ifii 
$tmp-»assign( 'blogConfig', $blog config ) ;// 博 客 配置 
$tmp-»assign( 'syncConfig', $sync config );// 同 步 配置 
$tmp-»assign( 'loginStat', $1oginStat );// 同 步 开始 
$tmp->output (); 
} 
} 
ob end flush(); 
?» 


9.7.5 RSS 订 阅 


RSS 订阅 功能 就 像 在 邮局 订 杂 志 一 样 ， 定 期 地 将 每 一 期 新 的 杂志 邮寄 给 订阅 的 人 ， 在 
此 微 博 系统 中 也 有 这 个 功能 ， 如 图 9-10 所 示 。 
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图 9-10 订阅 功能 
下 面 通过 一 段 代 码 进行 讲解 ， 其 代码 (rss.php) 如 下 : 


(336 < OO EO a 
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< 


«?php 

error reporting(E ALL); 

header("Content-Type: text/xml"); 

require once(dirname( FILE )."/database/config site.php");// 调 入 站 点 配置 
页 面 

require once(dirname( FILE )."/database/config mysql.php");// 调 入 链接 数 
据 库 页 面 

require once(dirname( FILE )."/class/class Blog.php");// 调 入 博客 分 类 页 面 
require once(dirname( FILE )."/include/function.php");// 调 入 功能 页 面 
$SgetPage = (isset($ GET['p']) && is numeric($ GET['p']) && $ GET['p'] >1)? 
intval($ GET['p']) : 1; 

$DB = database () ; //1]JT 9t ifi] 

$blogArr = BlogAction::getBlog($getPage,50); 

$DB-»close(); 

unset ($DB) ; 

echo '«?xml version-"1.0" encoding-"utf-8"?»5'; 

echo '«rss version="2.0">';// 显 示 版 本 

echo "<channel>";// 显 示 通 道 

echo 

"<title><! [CDATA[".stripslashes ($blog config['sitename'])."]]»«/title»"; 
// 显 示 博 客 标题 

echo "«link»".$blog config['siteurl']."</link>";// 显 示 博 客 链接 

echo "«description»«! [CDATA[".stripslashes (strip tags($blog config 
['siteintro']))."]]»«/description»"; //1iik 

echo "«generator»".stripslashes($blog config['nickname'])."«/generator»"; 
// 触 发 器 

echo "<language>zh-cn</1anguage>";// 页 面 字符 

echo "<copyright> 开 发 日 记 技术 支持 </copyright>"; 

echo "<image>"; 

echo "«url»".$blog config['siteurl']."/".$blog config['avatar upload']. 
"avatar.jpg«c/url»"; 

echo "«/image»"; 

for($i-0;$i«count ($blogArr['Blog']); $i++) 

t 


$arr = $blogArr['Blog'][$i]; 
echo "<item>"; // 条 款 
echo "«title»«! [CDATA[".strip tags ($arr['message'])."]]></title>";// 标 题 
echo "«link»".$blog config['"siteurl']."</1Link>"z// 链 接 
echo "«pubDate»".date('r',$arr['dateline']) ."</pubDate>";// 实 际 日 期 
echo "<description><! [CDATA[";// 描 写 
if( $arr['picture'] != "" ) 
{ 
echo "<a href-".$blog config['pic upload'].$arr['piclink']."» 
«img src-".$blog config['pic upload'].$arr['picture']." border=0></a>";// 描 述 
$ 
echo "]]></description>"; 
echo "</item>"; 
) 
echo "«/channel»"; 
echo c/rss»"; 
2> 


————————————————————————————H"" » 
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97.6 ”关注 其 他 微 博 


微 博 是 一 个 交流 工具 ， 除 了 让 别人 关注 你 ， 你 也 可 以 关注 别人 ， 在 本 微 博 系统 里 也 可 
实现 这 个 功能 。 如 图 9-11 所 示 。 
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9-11 关注 其 他 人 


下 面 通过 一 段 代码 进行 讲解 ， 其 代码 如 下 : 


<?php 
require once (dirname( FILE )."/global.php"); 
// 调 入 页 面 
if( !$1oginstat ) 
t 
header ("location:./login.php"); 
// 页 面 头 部 信息 
) 
else 
{ 
$getPage = (isset($ GET['p']) && is numeric($ GET['p']) && $ GET['p'] > 1) ? 
intval ($ GET['p']) : 1;// 获 得 信息 
$friendType = (isset($ GET['t']) && $ GET['t'] == "fans") ? 2 : 1; 
// 友 情 类 型 
$DB = database(); 
$friendArr = BlogAction: :getFriend|("' ftype' -". $friendType, "' fid' ", $getPage, 20) ; 
// 博 客 活 动 
$DB-»close(); 
unset ($DB) ; 
$pageArr = pageAction::blogPage ($friendArr['Total'],20,$getPage); 
$tmp = template ("friend.html"); 
// 模 板 页 面 
$tmp->assign( 'blogConfig', $blog config ); 
// 博 客 配置 
$tmp-»assign( 'loginStat', $1oginsStat ) 7 
/ [83 
$tmp-»assign( 'friendType', SfriendType ); 
// 朋 友 类 型 


$tmp-»assign( 'friendArr', $friendArr ); 


r ë 
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$tmp-»assign( 'pageArr', $pageArr ); 
$tmp-»output () ; 
unset ($tmp); 

H 

ob end flush(); 

?» 
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今天 老 同 学 同事 C 开发 完了 整个 后 台 功 能 。 后 台 功 能 其 实 就 微 博 管理 功能 ， 每 一 个 功 
能 都 是 用 来 管理 微 博 的 ， 如 账户 管理 ， 微 博 设 置 、 同 步 更 新 、 订 阅 以 及 关注 其 他 微 博 。 作 
为 开发 者 来 说 ， 一 定 要 探寻 浏览 者 的 意图 ， 看 看 什么 样 的 功能 最 为 适用 。 作 为 开发 者 的 我 ， 
和 团队 成 员 多 次 论证 ， 最 终 选择 了 这 几 个 常用 功能 。 


9.8 JJ) iX 


我 们 终于 看 到 胜利 的 曙光 了 ， 整 个 项 目 只 剩 下 测试 发 布 工作 了 。 最 后 的 项 目测 试 工 作 
由 我 来 完成 ， 我 需要 将 测试 中 发 现 的 不 足 反 应 给 开发 小 组 进行 修改 。 在 此 我 将 工程 命名 为 
“09weibo”。 


9.8.1 系统 运行 浏览 


当 系 统 运行 后 ， 用 户 可 以 进入 微 博 里 面 ， 随 时 发 布 自己 需要 的 微型 博文 ， 如 图 9-12 所 
示 为 正在 发 布 微 博 。 
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9-12 ”发 布 微 博 
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9.82 验收 


今天 我 来 到 了 曾经 的 母校 ， 学 校 好 像 开 学 了 ， 多 年 前 的 今天 ， 我 带 着 行李 来 到 重庆 ， 
这 座 忧 伤 而 古老 的 城市 ， 不 管 我 愿 不 愿意 ， 它 都 欣然 地 接受 了 我 。4 年 前 ， 我 上 了 大 学 ， 全 
家 人 都 为 我 高 兴 ， 因 为 我 是 我 们 家 第 一 个 大 学 生 ， 在 祖宗 十 八代 都 没有 出 现 过 这 一 幕 。4 年 
后 ， 我 大 学 毕 了 业 ， 来 到 了 这 家 网 络 公司 ， 成 为 一 个 小 职员 ， 虽 然 觉得 不 可 思议 ， 但 也 很 
高 兴 。 今 天 我 完成 了 微 博 系统 ， 在 验收 的 时 候 ， 整 个 公司 同事 为 我 们 这 个 项 目 响起 了 热烈 
的 掌声 。 

在 后 期 维护 上 ,我们 也 安排 了 分 工 ， 留 下 了 同事 A 的 电话 作为 全 天 候 服务 热线 。 而 我 、 
同事 B、 同 事 C 则 开始 为 系统 升级 做 准备 ， 并 考虑 系统 优化 等 方面 的 问题 。 


9.8.3 总 结 


微 博 是 最 近 两 三 年 才 火 起 来 的 互联 网 产品 ， 各 大 门户 都 在 开发 自己 的 微 博 系统 。 要 想 
获得 客观 的 回报 ， 首 先 需要 累积 足够 的 人 气 。 关 于 开发 微 博 ， 我 总 结 了 如 下 两 点 经 验 。 

1) 正确 理解 微 博 是 什么 

许多 公司 开发 微 博 ， 但 是 有 许多 程序 员 都 不 明白 微 博 是 个 什么 东西 ， 开 发 微 博 ， 一 定 
要 将 其 定位 把 握 准 。 第 一 ， 从 内 容 长 短 来 讲 ， 微 博 是 相对 于 强调 版 面 布置 的 博客 来 说 ， 微 
博 的 内 容 组 成 只 是 由 简单 的 只 言 片 语 组 成 ， 从 这 个 角度 来 说 ， 对 用 户 的 技术 要 求 门 槛 很 低 ， 
而 且 在 语言 的 编排 组 织 上 ， 没 有 博客 那么 高 ; 第 二 ， 微 博 开 通 的 多 种 API 使 得 大 量 的 用 户 可 
以 通过 手机 、 网 络 等 方式 来 即时 更 新 自己 的 个 人 信息 ， 所 以 在 开发 的 过 程 中 ， 一 定 多 开 
发 出 移动 终端 设备 的 程序 ， 方 便 用 户 在 各 个 环境 更 新 与 阅读 信息 。 微 博 草根 性 更 强 ， 且 广 
泛 分 布 在 桌面 、 浏 览 器 、 移 动 终端 等 多 个 平台 上 ， 有 多 种 商业 模式 并 在 ， 或 形成 多 个 垂直 
细 分 领域 的 可 能 ， 但 无 论 哪 种 商业 模式 ， 应 该 都 离 不 开 用 户 体验 的 特性 和 基本 功能 。 

2) 微 博 的 功能 重 在 交互 

在 开发 微 博时 ， 许 多 人 理解 就 是 把 博客 缩小 ， 字 数 限制 在 一 百 多 个 字 ， 其 实 理解 完全 
错误 ， 博 客 的 功能 重 在 展示 ， 就 像 写 日 记 ， 可 以 抒发 情感 ， 描 述 大 量 的 内 容 ， 而 微 博 不 同 
它 的 功能 贵 在 交互 ， 与 博客 上 面对面 的 表演 不 同 ， 微 博 上 是 背 对 脸 的 交流 ， 就 好 比 你 在 电 
脑 前 打 游 戏 ， 路 过 的 人 从 你 背后 看 着 你 怎么 玩 ， 而 你 并 不 需要 主动 和 背后 的 人 交流 。 可 以 
一 点 对 多 点 ， 也 可 以 点 对 点 。 当 你 跟随 一 个 自己 感 兴趣 的 人 时 ， 两 三 天 就 会 上 瘾 ， 微 博 重 
点 是 打造 一 个 新 时 代 的 社交 圈子 。 


OA 在 线 办 公 系 统 (€) 


随 着 中 国 经 济 和 互联 网 的 高 速 发 展 , 传统 办 公 模 式 越 
来 越 不 适应 现在 企业 的 发 展 ， 企 业 需 要 将 新 技术 、 新 设备 
用 到 办 公 室 ， 让 办 公 人 员 进 入 高 效 办 公 状 态 。 此 时 ， 在 线 
办 公 走 进 了 人 们 的 视线 ， 它 的 快速 、 高 效 深 受 企业 青睐 。 

本 章 将 详细 讲解 OA 在 线 办 公 系 统 的 构建 方法 ， 旨 在 
让 读者 牢固 掌握 OA 在 线 后 台数 据 库 的 建立 、 维 护 以 及 前 
台 应 用 程序 的 开发 ， 为 其 以 后 深入 学 习 打 下 坚实 的 基础 。 


War 一 


10.1 人 生 第 一 次 飞翔 
秋天 来 了 ， 我 却 丝毫 没有 感觉 到 凉意 。 在 重庆 ， 夏 天 过 完 就 紧 接着 过 冬天 ， 有 的 时 候 
难免 会 令 人 有 些 郁 间 。 就 在 这 个 季节 ， 我 辞 掉 了 工作 和 大 学 同学 组 建 了 一 个 工作 室 。 
10.1.1 项 目 来 源 
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工作 室 成 立 快 半年 了 ， 终 于 接 到 了 一 个 大 的 项 目 一 一 凤 鸣 山 中 小 学 校 的 在 线 办 公 系 统 。 
这 是 我 遇 到 的 第 一 个 大 项 目 ， 它 也 是 工作 室 的 开业 之 举 ， 对 我 们 工作 室 来 说 ， 意 义 重 大 ， 
不 过 我 相信 我 们 能 够 把 它 做 好 。 


10.1.2. 组建 团队 


(03005 (09 (09, $8. 
接 到 项 目 ， 我 们 组 建 了 一 个 团队 ， 成 员 如 下 。 
TuanA: 


来 自 富 底 之 地 浙江 ， 这 是 一 个 富 甲 一 方 的 地 方 。 来 公司 工作 不 到 三 个 月 ， 酷 爱 学 习 ， 
是 公司 最 为 勤奋 的 人 ， 买 了 许多 辅导 书籍 、Java、PHP 等 书籍 ， 什 么 东西 都 会 ， 但 是 都 是 不 
精通 一 门 ， 但 策划 经 验 十 分 优秀 。 他 十 分 上 进 ， 很 早 就 央求 我 给 他 项 目 做 ， 以 迅速 提高 自 


己 的 水 平 。 
任务 : 负责 项 目 规划 ， 撰 写 系统 设计 规划 书 。 
TuanB: 


来 自 刘三姐 的 故乡 广西 ， 但 是 我 没 听 他 唱 过 山歌 ， 只 是 在 KTYV 的 时 候 ， 听 他 唱 过 刘 德 
华 和 周杰伦 的 歌 。 我 和 他 相识 于 公司 外 出 旅行 ， 他 技术 功底 扎实 ， 委 任 热情 ， 是 公司 程序 
员 中 升 职 人 员 的 热门 。 

任务 : 负责 需求 分 析 和 数据 库 设 计 。 

TuanC: 

是 我 的 发 小 ， 毕 业 后 曾经 开 过 一 个 软件 公司 ， 因 资金 缺乏 ， 公 司 倒闭 了 ， 现 在 整 天 在 
家 无 所 事 事 。 为 了 重新 提起 他 的 士气 ， 我 把 他 硬 拉 进 这 个 项 目 组 ， 和 希望 通过 这 个 项 目 重新 


树立 他 的 自信 。 
任务 : 负责 设计 日 常 办 公 的 常用 功能 模块 。 
TuanD: 


对 于 开发 软件 来 说 ， 他 是 一 个 天 才 ， 可 能 这 和 他 的 勤奋 分 不 开 。 他 大 多 时 候 都 在 看 书 
籍 ， 看 国内 的 开源 源 代码 ， 是 朋友 公司 最 具 潜力 的 程序 杀手 。 正 是 因为 看 重 了 他 的 潜力 ， 
所 以 才 让 朋友 介绍 过 来 帮忙 。 

任务 : 负责 设计 基本 管理 功能 模块 。 
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我 : 

目前 当 了 一 个 项 目 副 经 理 ， 多 亏 江 湖人 抬 爱 ， 按 其 能 力 来 说 ， 我 依然 工 界 一 只 刚刚 起 
Xp E. 

任务 : 负责 系统 整体 框架 设计 ， 并 协调 项 目 中 各 个 模块 的 进展 。 

具体 职能 结构 如 图 10-1 所 示 。 


TuanB 


负责 需求 分 析 和 数据 
TuanA 库 设计 


EAMUS, SEES 
Ps TuanD 


设计 规划 书 
设计 基本 管理 功能 模块 


TuanC 
日 常 办 公 的 常用 功能 模块 j 
协调 我 
框架 设计 和 协调 


图 10-1 职能 结构 图 


整个 项 目的 具体 操作 流程 是 : 项 目 规划 一 数据 库 设 计 一 框架 设计 一 系统 信息 管理 、 用 
户 管理 、 用 户 功 能 。 


10.1.3 DÈX 
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在 接 到 这 个 项 目 后 ， 我 们 召开 了 第 一 次 会 议 ， 就 项 目的 大 小 、 功 能 和 需求 进行 了 分 析 。 
应 用 程序 的 开发 采用 目前 比较 流行 的 ADO 数据 库 访问 技术 ,并 将 每 个 数据库 表 的 学 有 和 操 
作 封装 到 相应 的 类 中 ， 使 应 用 程序 的 各 个 窗 体 都 能 够 共享 对 表 的 操作 ， 而 不 需要 重复 编码 ， 
使 程序 更 加 易于 维护 ， 从 而 将 面向 对 象 的 程序 设计 思想 成 功 应 用 于 应 用 程序 设计 中 ， 这 也 
是 本 系统 的 优势 和 特色 。 

最 后 我 做 了 一 个 简单 的 总 结 : “要 开发 一 个 OA 在 线 办 公 系 统 ， 首 先 需要 进行 系统 需 
求 分 析 和 总 体 设 计 ， 分 析 系 统 的 使 用 对 象 和 用 户 需 求 ， 设 计 系统 的 体系 结构 和 数据 库 表 结 
构 ， 决 定 使 用 的 开发 工具 和 后 台数 据 库 ， 规 划 项 目的 开发 进度 等 。” 

大 家 一 致 提议 TuanA 尽快 作出 规划 书 ， 后 续 工 作 将 以 规划 书 为 基础 进行 扩展 。 
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10.2 ”系统 概述 和 总 体 设 计 


今天 TuanA 做 出 了 完整 的 项 目 规划 书 ， 整 个 规划 书 分 为 如 下 两 个 部 分 。 
口 系统 需求 分 析 
O ”系统 运行 流程 


10.2.4. 系统 需求 分 析 
在 线 OA 办 公 的 用 户主 要 是 学 校 的 所 有 教职员 工 ， 让 其 在 一 个 平台 工作 ， 具 体 功能 如 下 。 
1. BADAR 


此 模块 是 针对 某 个 单 用 户 所 包括 的 功能 内 容 ， 分 为 行政 通知 、 工 作 安排 、 资 料 下 载 、 
日 程 安排 、 待 办 提醒 和 会 议 通知 等 功能 。 


2. 行政 管理 

行政 管理 是 指 行政 部 安排 的 工作 ， 包 括 行政 通知 、 工 作 安排 、 资 料 下 载 、 会 议 通知 和 
公 病 事假 。 

3. 教学 管理 

教学 管理 是 本 系统 的 核心 ， 包 括 课程 表 和 成 绩 管理 。 

4. 教务 管理 

教务 管理 是 本 系统 的 核心 ， 教 务 管理 分 为 实验 室 预约 、 公 共 教 室 预约 、 演 示 实 验 室 登 
记 等 管理 。 


根据 需求 分 析 中 总 结 的 用 户 需求 来 设计 系统 的 体系 结构 ， 每 一 个 叶 结 点 是 一 个 最 小 的 
功能 模块 。 每 一 个 功能 模块 都 需要 针对 不 同 的 表 完成 相同 的 数据 库 操作 ， 即 添加 记录 、 删 


10.22 ”系统 运行 流程 


在 此 模拟 了 系统 的 运行 情景 : 运行 系统 后 ， 首 先 会 弹出 用 户 登录 对 话 框 ， 对 用 户 的 身 
份 进行 认证 并 确定 用 户 的 类 型 。 如 果 需 要 对 普通 用 户 进行 管理 ， 则 使 用 admin 用 户 登 录 ; 
如 果 要 创建 其 他 用 户 ， 可 以 在 用 户 管理 模块 创建 和 管理 ;否则 建议 使 用 user 用 户 进行 登录 ， 
如 图 10-2 所 示 。 
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10-2 ”登录 对 话 框 


10.3 数据 库 设 计 


阳光 明媚 


经 过 两 天 的 奋战 ，TuanA 的 系统 规划 工作 终于 大 功 告 成 了 。 有 了 这 个 规划 书 ， 我 们 以 
后 的 工作 就 有 目的 性 了 。 接 下 来 ， 需 要 TuanB 出 马 来 完 成 数据 库 的 设计 工作 。 


10.3.1 数据 库 结 构 的 设计 


具体 的 数据 库 设计 ，TuanB 参考 了 Tuana 的 需求 分 析 。 由 需求 分 析 的 规划 可 知 整个 项 
HIRA 36 种 信息 ， 所 以 对 应 的 数据 库 也 需要 包含 这 36 种 信息 ， 从 而 系统 需要 包含 36 个 
数据 库 表 ， 下 面 将 对 重要 的 6 个 数据 库 信 息 表 进 行 讲解 。 

TuanB 给 出 了 以 下 具体 数据 库 表 的 书面 文件 。 

(1) 班级 信息 表 (classset)， 用 来 保存 各 个 班级 信息 ， 表 结构 如 表 10-1 所 示 。 


310-1 班级 信息 表 


字段 类 型 属性 nun RU S 
id int(11) EJ auto increment 
classid char(4)  gbk chinese ci EJ 
gradeid char(4) —gbk chinese ci EJ 
classname char(20) gbk chinese ci 8 
(2) OA 管理 部 门 信息 表 (managementb)， 用 来 保存 各 个 部 门 的 基本 信息 ， 表 结构 如 表 10-2 
所 示 。 
表 10-2 管理 部 门 信息 表 
字段 类 型 整理 Et nu RA LI 
id tinyint(4) 8 auto increment 
manageid tinyint(4) e 0 
managename varchar(20)  gbk chinese ci E 
managetel ^ varcha(100) gbk chinese ci z 
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(3) 用 户 管理 信息 表 (members)， 用 来 保存 各 个 登录 信息 表 ， 表 结构 如 表 10-3 所 示 。 
表 10-3 用 户 管理 信息 表 


字段 类 型 属性 Nul RA 5 
userid int(11) 否 auto increment 
username varchar(20) gbk chinese ci EJ 
realname ^ varchar(50) gbk chinese ci 是 NULL 
password ^ varchar32) gbk chinese ci EJ 
groupid tinyint(1) S 0 
webgroupid tinyint(4) rimi 
admining — int(6) 是 0 
school varchar(50) gbk_chinese_ci 是 NULL 
subjectid — tinyint(6) S 0 
manageid — tinyint(4) = 0 


(4) OA 系统 管理 表 (oa_adminlog)， 用 来 保存 系统 信息 ， 表 结构 如 表 10-4 所 示 。 
R104 系统 管理 表 


字段 类 型 整理 属性 non RU LI 
adminlogid int(15) 否 auto_increment 
action varchar(50) — gbk chinese ci El 
script varchar(255) gbk_chinese_ci 否 
date varchar(10) —gbk chinese ci Ej 
ipaddress — varchar(16) — gbk chinese ci E 


(5) 课程 管理 表 (subject)， 用 来 保存 课程 管理 表 ， 表 结构 如 表 10-5 所 示 。 
表 10-5 课程 管理 表 


字段 类 型 整理 属性 nu RU So 
id tinyint(4) z auto_increment 
subjectid  tinyint(4) 否 0 
subjectname varchar(20) gbk chinese ci Ej 


(6) 用 户 信息 表 (userinfo)， 用 来 保存 各 种 用 户 信息 ， 表 结构 如 表 10-6 所 示 。 
表 10-6 用 户 信息 表 


字段 类 型 整理 属性 Null RU 9» 
id int(11) 否 auto increment 
userid — int(11) 否 0 
sex tinyint(4) S8 0 
address ^ varchar100) gbk chinese ci z 
work varchar(100) gbk_chinese_ci Ej 
tel varchar20) — gbk chinese ci EJ 
tel2 varchar20) — gbk chinese ci E 
tel3 varchar(20) —gbk chinese ci EJ 
qq varchar(20) gbk_chinese_ci 否 
email varchar40) gbk_chinese_ci EJ 
msn varchar40) — gbk chinese ci EI 
tableleft — varchar(50) — gbk chinese ci r3 
tableright varchar(50) — gbk chinese ci 否 


E3«- 
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10.3.2 ”数据 库 配置 信息 


当 创 建 好 数据 库 后， 数据 库 设 计 人 员 必 须要 为 数据 库 提供 配置 信息 ， 供 程序 人 员 调 用 ， 
下 面 是 Tuan B 编写 的 实现 代码 (config php): 


< 


<?php 

* 

凤 鸣 山 中 小 学 网 络 办 公 室 

er 

// 系 统 配置 信息 

$servername = 'localhost'; // 数据 库 服 务 器 
$dbusername = 'root'; // 数据 库 用 户 名 
$dbpassword = '1234'; // 数据 库 密码 
$dbname = 'oa'; // 数据 库 名 
$charset = 'gbk'; // 数 据 库 字 符 编 码 


$tablepre = 'oa '; 
$dbservertype = 'mysql'; 
$usepconnect - '1'; 


// 表 名 前 级 ， 同 一 数据 库 安装 多 个 系统 请 修改 此 处 


// 不 能 修改 此 处 


// 数据 库 连 接 方式 0=connect， 1=pconnect 


$force html = 'false'; // 强 制 更 新 

$showtime = '0'; // 是 否 显示 页 面 执行 时 间 
$admin root-'admin'; // 管 理 目录 

$rootpath = 'http://127.0.0.1/web/100a'; // 系 统 根 目录 

$school name =' 凤 鸣 山 中 小 学 网 络 办 公 室 '; // 学 校 名 称 

$school type = '2'; // 学 校 类 型 1: 小 学 版 ?2 :中 


学 版 :12 中 小 学 九 年 制 学 校 ;3: 高 中 版 ,现在 没有 实现 


$register key = 'school'; // 邀 请 码 , 注册 时 需要 
$style = 'test'; // 当 前 所 选 风格 
$dellog pass = '31'; // 后 台 登 录 和 操作 记录 删除 密码 
$sitename = ' 凤 鸣 山 中 小 学 '; // 网 站 名 称 
$siteurl = '£'; // 网 站 地 址 
$sitemaster = ' 大 兵 小 将 '; // 网 站 站 长 名 称 
$siteemail = 'shandao6fm.com'; // 网 站 站 长 邮箱 
$sitetitle = “" 凤 鸣 山 中 小 学 网 络 办 公 室 201177 // 网 站 标题 
$sitedescription = “" 凤 鸣 山 中 小 学 网 络 办 公 室 ' 7 // 网 站 描述 
$sitekeywords = ' 学 校 网 站 ， 软 件 , 学 校 oa 系统 , 学 校 办 公 ' ; // 网 站 关键 词 
Suppath = 'upfile/'; // 文 件 上 传 的 目录 (后 面 加 上 /) 


$uptemp-$uppath."temp/"; 
$MAX FILE SIZE = '100000000'; 


// 文 件 上 传 的 临时 目录 (后面 加 上 /) 
// 文 件 上 传 大 小 限制 单位 是 b 


$uptypes = 'jpglbmplpnglgifljpegltxt|rar|jar|exe|xls|doc'; 
p 


// 人 允许 上 传 文件 的 类 型 
$perpage - '20'; 
$pagenavpages = '5'; 
$strnum = '30'; 

//set index 

$outtypeids = '7,8,9,10'; 


// 翻 页 文章 数 
// 页 面 浏览 数 
// 标题 显示 文字 数 


// 首页 信息 显示 栏目 


$class subject arr =' 语 文 ,数学 , 外 语 , 科 学 ,社会 ,思想 , 政治 , 体育 , 美术, 劳 技 , 电脑 , 音乐 ， 


实践 活动 , 自习 , 课外 活动 ,综合 ' 7 


$includepic arr = ', [转告 ] [紧急 ], [推荐 ] , [注意 ]，[ 换 课 ] ,[ 公 开课] ' ; 


$ftp ip = '10.56.20.10'; 
Sport = 121"; 
?» 


// 内 网 ip 地 址 
//ftp 端口 
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10.3.3 ”系统 配置 信息 


创建 数据 库 配 置信 息 , 需要 编写 一 段 代 码 (global.php) 来 实现 整个 系统 的 配置 信息 , 供 程 
序 员 调 用 和 系统 调用 ， 具 体 如 下 : 


<?php 

unset ($dbservertype); 

// 配 置信 息 

require './config.php'; 
LLELELLELELLLLLLLLESCLICS C RRPRLRLLCLCLLLLLL LLL LLL LLL LLLI 
// 负 责 数据 库 

$dbservertype = strtolower ($dbservertype); 
$dbclassname-"./include/db $dbservertype.php"; 

require once "$dbclassname"; 

// 负责 数据 库 表 

$tables = array('content', 'setting', 
'type','manage','soft','articles', 'members','images', 'message', 
'adminlog','loginlog',' 'chajian','friendlinks',''ads','soft', 


'leave','schedule','file','message','letter', 'userinfo', 'favorite', 
'clas stable', 


'y class','y type','y setting','y content','ftp' ) 7 
foreach ($tables as $tablename) ( 
$('table '.$tablename) = $tablepre.$tablename; 
) 
unset ($dbclassname, $dbservertype,$tables,$tablename,$dbservertype); 
// 保存 系统 配置 
$db = new FMysql;// 实 例 化 数据 库 设计 
$db->appname=" 大 兵 小 将 "; // 设 计 者 名 称 
$db->appshortname=" 校 园 2010 网 络 办 公 室 "// 系 统 名 称 ; 
$db->database=$dbname; 
$db->server=$servername; 
$db->user=$dbusername; 
$db->password=$dbpassword; 
$db-»connect () ; 
$db-»query("SET NAMES '$charset'"); 
unset($dbhost, $dbuser, $dbpw, $dbname, $pconnect); 
// 实 现 功能 
require once './include/functions.php'; 
MLLLILLLLLLLLLLLLLLLLLLLLLLE EOD | RRRPRLLLLLLLLLLLLLLLLLLLLLLL LLLI 
// 模 板 功能 
require once('./include/tpl.class.php'); 
// 保 存 模板 
$templates dir-'./templates/'.$style.'/html'; 
$tpl = new MicroTpl($templates dir); 
$tpl-»force html-$force html; 
unset($templates dir); 
$css-"«LINK href-templates/$style/css/style.css rel-stylesheet 
type-text/css»"; 
?» 
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今天 TuanB 完成 了 数据 库 设 计 阶 段 的 工作 。 这 是 我 们 工作 室 开 张 的 第 一 个 项 目 ， 无 论 
a< ———————— HÁÁá—————————— ———— MÉTIER z 


810€ OAZAAARH H 


是 在 数据 库 设 计 、 还 是 在 功能 需求 方面 ， 我 们 都 进行 了 深入 的 研究 。 这 个 数据 库 的 表 比 较 
多 ， 而 且 都 有 许多 关系 ， 在 设计 时 ， 可 以 使 用 数据 库 设 计 软 件 ， 容 易 看 清楚 数据 库 结 构 。 
在 建立 好 数据 库 后 ， 对 数据 库 配置 信息 和 系统 配置 信息 进行 编程 ， 这 些 工 作 完 成 后 ， 就 可 
以 开发 系统 框架 设计 或 者 其 他 的 功能 。 


10.4 系统 框架 设计 


数据 库 设计 阶段 的 工作 完成 后 ， 整 个 项 目 马 上 进入 了 第 三 阶段 一 一 系统 框架 设计 。 此 
阶段 的 工作 是 由 我 来 完成 的 ， 我 根据 规划 书 和 数据 库 结 构 ， 很 快 想 好 了 整个 项 目的 框架 
结构 。 


10.4.1 验证 码 


验证 Ca 序 恶 意 攻击 系统 而 设 定 的 ， 它 会 随机 产生 几 个 字符 ， 
输入 正确 后 ， 才 能 完成 一 系列 的 操作 ， 如 图 10-3 所 示 为 验证 码 图 片 。 


风 鸣 山中 小 学 网 络 办 公 室 - 风 罗 山中 小 学 网 络 办 公 室 2011 x 
E TLAT TJ LCS 


HPER | 天 于 直系 于 


LIS & 
ER: » 
V: [a385] 
AW: ELERII x 
请 输入 已经 通过 证 核 的 用 户 名 与 密 玛 进行 总 疆 ! 一 [点 击 注册 ] 
Ej 
图 10-3 ”验证 码 
下 面 通 过 一 段 代 码 (chknumberphp) 进 行 讲解 ， 具 体 如 下 : 


<? 

Function getRandNumber ($fMin, $fMax){ 
srand( (double)microtime ()*1000000); 
$fLen = "£&0".strlen($fMax). "d"; 
Return sprintf($fLen, rand($fMin,$fMax)); 
H 

$str-getRandNumber (1000, 9999); 

setcookie ("code", $str); 


//function images ($str){ 


//$str-random(4); // 随 机 生成 的 字符 串 


$width = 50; // 验 证 码 图 片 的 宽度 
$height = 22; // 验 证 码 图 片 的 高 度 
Gheader ("Content-Type:image/png"); 
//$ SESSION["code"] = $str; 

//echo $str; 

Sim-imagecreate ($width, $height); 
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// 背 景色 

$back-imagecolorallocate ($im, OxFF, OxFF, OxFF) ; 

// 模 糊 点 颜色 

$pix-imagecolorallocate ($im,187,230,247); 

// 字 体 色 

$font-imagecolorallocate ($im, 41,163,238); 

// 绘 模糊 作用 的 点 

mt srand(); 

for ($i=0; $i<1000; $i++) 

{ 

imagesetpixel ($im,mt rand(0,$width),mt rand(0,$height),$pix); 
} 
imagestring($im, 5, 7, 3,$str, $font); 
imagerectangle ($im,0,0,$width-1,$height-1,$font); 
imagepng ($im); 

imagedestroy ($im); 

//$ SESSION["code"] = $str; 

Ty 

pol 


10.4.2 注册 


这 是 在 线 办 公 的 系统 ， 如 果 没 有 注册 ， 没 有 用 户 名 和 密码 ， 一 切 都 只 能 停 在 主 界面 ， 
什么 都 不 能 做 ， 如 图 10-4 所 示 为 注册 页 面 。 
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10-4 注册 页 面 


下 面 通过 一 段 代 码 (registerphp) 进 行 讲 解 ， 具 体 如 下 : 


«?php 


require './global.php';// 调 入 页 面 
if (!isset($step)) 


$step=1; 

if ($action=="reg") 

{ 

if ($ POST['reg key']!-$register key) 
t 


showmessage (" 对 不 起 邀请 码 错误 ","?filename=reg&step=2") ; 
exit; 
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$reg username-addslashes ($username); 
$reg realname-addslashes ($realname); 
$reg password-addslashes ($password); 
$reg password-md5 ($reg password); 
// 检 测 是 否 有 人 注册 
$sql-"select * from members where username-'$reg username' or 
realname-'$reg realname' limit 1"; 
$result-$db-»query ($sql) ; 
if($db-»num rows ($result)==1) ( 
showmessage (" 对 不 起 已 经 有 人 注册 了 ", "?£ilename-reg&step-2"); 
exit; 
H 


// 开 始 存 入 注册 信息 
$sql="INSERT INTO 'members' ( 'username' , 'realname' , 'password' , 
'groupid' , 
'admining','subjectid','manageid' ) 
VALUES ( '$reg username', '$reg realname', '$reg password', '99' , 
'-1',$subjectid, $manageid) ;"; 
$db-»query ($591) ; 
$query id-$db-»insert id(); 
// 生 成 用 户 资料 
$query-"INSERT INTO 'userinfo' ( 'id' , 'userid' ) 
VALUES ('', '$query id');"; 
$db-»query ($query); 
showmessage ("E MK! 注册 成 功 请 登录 , 你 没有 相关 权限 .请 等 待 , 管理 员 会 开通 你 的 账号 
","index.php"); 
exit; 
) 
switch ($step){ 
oases 
break; 
case UEUE 
// 部 门 数据 读 取 
$query-"SELECT * FROM 'management' ORDER BY 'manageid' ASC"; 
$result-$db-»query ($query); 
while($s-$db-»fetch array ($result)){ 
$manage data.-"«option 
value-'$s [manageid] '»$s [managename] «/option»"; 
— 
// 学 科 数 据 读 取 
$query-"SELECT * FROM 'subject' ORDER BY 'subjectid' ASC "; 
$result-$db-»query ($query); 
while($s-$db-»fetch array ($result)){ 
$subject data.="<option 
value-'$s[subjectid]'»$s[subjectname]«/option»"; 
} 
$tpl-»assign("subject data", $subject data); 
$tpl->assign ("manage data", $manage data); 
break; 


} 

$tpl->assign('step', $step); 
$tpl-»display('register.html'); 
?» 
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10.4.3 上 传 


在 线 上 传 功 能 是 OA 系统 中 必 不 可 少 的 ， 不 管 是 什么 栏目 ， 我 们 要 保证 上 传 文件 必须 
存在 ， 并 且 要 排除 可 能 导致 系统 运行 不 良 等 问题 。 解 决 方案 的 代码 (editorphp) 如 下 : 


«?php 
require './global .php';// 配 置信 息 
switch ($action){ 
case 'upfile': 
if($do)t 
if (empty ($userfile)){ 
exit ("对 不 起 ,没有 上 传 文件 ! m; 
) 
if(S$userfile size--0)( 
exit ("对 不 起 ,上 传 文件 的 字 节 数 为 0! 7); 
} 
if(!is uploaded file($userfile))( 
exit (" 对 不 起 ,文件 上 传 失败 ! m); 
) 
if($userfile size»$MAX FILE SIZE)( 
$MAX FILE SIZE-$MAX FILE SIZE/1000; 
exit ("对 不 起 , 你 上 传 的 文件 不 得 超过 $MAX_FILE SIZE k! "); 
} 
$notuptypes-$notuptypes?$notuptypes:'.phpl.aspl.jspl.cgil.dll'; 
if($type-file type($userfile name, $notuptypes) ) { 
exit ("对 不 起 , 请 不 要 上 传 " . $type. "格式 的 文件 ! m; 
} 
$ndatey-date ("Y",time()); 
$ndate-date( "m", time());//H[[R] 
$ndateday-date( "d", time());//HHÀ 


$newfilepath-$ndatey."/".$ndate."/".$ndateday.rand(100,999).S$userfile 
name; // 新 文件 路 径 
$newfile-$uppath."attach/".$newfilepath; 
$savepath=$rootpath.'/' .$newfile;// 设 置 文件 路 径 
$newfile size=$userfile size/1000000; 
$newfile size-number format ($newfile size,2,".",""); 
$newfile size-$newfile size."M"; 
if 
(empty ($filename) ) ($tempfile-explode(".",$userfile name);$filename-$temp 
file[0];); 
$updir-$uppath."attach/"."$ndatey/$ndate"; 
createdir ($updir); 
if (copy($userfile,$newfile))( 
$hash-getcode () ;添加 记录 
$query-"INSERT INTO '$table soft' ( 'softid' ,'postid', 
'softname' ,'softpath', 'softsize' , 'number' , 'money' , 'other' ) 
VALUES ('','$postid','$filename' ,'$newfilepath', '$newfile size', '0', 
'$money', '$hash')"; 
$r-$db-»query ($query) ; 
$query id-$db-»insert id(); 
$out-"«center»«FIELDSET align-center»«LEGEND 
align-center»«font color=red> 文 件 上 传 成 功 ! «/font»«/LEGEND»«br»[ «a href=# 
onclick=\"Addfile ('$query id','$filename')\"> 单 击 这 里 添加 到 编辑 器 中 
</a> ]</fieldset><center>"; 


人 多 a 
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< 


łelse{ 
$out="<center><FIELDSET align=center><LEGEND align=center> 
<font color=red> 文 件 上 传 失 败 ! </font></LEGEND></fieldset><center>"; 
echo "«html» 
«head» 
<title> 文 件 上 传 </title> 
«script language-'JavaScript'» 
<!-- 
function Raddfile(fileid,filename){// 添 加 文件 
le-window.opener.document.forml.addfile.lengthe*; 
window.opener.document.forml.addfile.options[le].text -filename; 
window.opener.document.forml.addfile.options[le].value -fileid; 
window.close(); 
) 
function Addswf(swfPath,width,height)( /7 添加 动画 
window.opener.frames.message.focus(); 
window.opener.frames.message.document.body.innerHTML4-'«object 
classid-clsid:D27CDB6E-AE6D-11cf-96B8-444553540000 
codebase-http: //download.macromedia.com/pub/shockwave/cabs/flash/swflash 
.cabéversion-6,0,29,0 width-'«width*' height-'-«height-'»«param name-movie 
value-'«swfPath*'»«param name-quality 
value-high»«param name-wmode value-transparent»«embed src-'-«swfPath-' 
width='+width+' 
height='+height+' quality=high 
pluginspage=http://www.macromedia.com/go/getflashplayer 
type-application/x-shockwave-flash wmode-transparent»«/embed»«/object»'; 
window.close(); 
) 
function Addpic (imagePath, note) ( /7 添加 照片 
window.opener.frames.message.focus(); 
window.opener.frames.message.document.execCommand ('InsertImage', 
false, imagePath); 
window.opener.frames.message.document.body.innerHTML4-'«br»'-«note; 
window.close(); 
) 
m 
</script> 
<LINK href=$rootpath/edit/site.css rel=stylesheet> 
</head> 
<BODY bgColor=menu topmargin=15 leftmargin=15 
>".$out."</body></html>"; 
Jelse( 
$tsize-$maxsize/1000; 
echo "<html> 
<head> 
<meta http-equiv='Content-Type' content='text/html; charset=gb2312'> 
<title> 文 件 上 传 </title> 
<LINK href-$rootpath/edit/site.css rel-stylesheet» 
</head> 
<BODY bgColor=menu topmargin=15 leftmargin=15 > 
<CENTER> 
<FIELDSET align=left> 
«LEGEND align=left> 文 件 上 传 </LEGEND> 
«form name-'form' method-'post' 
action-'editor.php?action-upfile&do-l&postid-$postid' 
enctype-'multipart/form-data' » 
«input type-'hidden' name-'MAX FILE SIZE' value-'$MAX FILE SIZE'» 


CO 让 二 全 生生 六 而 二 > 
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文件 : «input type-'file' name-'userfile' size=23><br> 名 字 : «input 
type-'text' name-'filename' 
size-23»&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; 
&nbsp; &nbsp; <br> 点 数 : «select name-money» 
<option value=0>0 点 数 </option> 
<option value=1>1 点 数 </option> 
<option value=2>2 点 数 </option> 
</select> 
&nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp; &nbsp; 
&nbsp;&nbsp; «input type-'submit' name-'Submit' value-' L f£' »«p» 
限制 大 小 : ".$tsize."K &nbsp;&nbsp; &nbsp;&nbsp; &nbsp; &nbsp; &nbsp; 
&nbsp;&nbsp;&nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp; &nbsp; 
&nbsp; &nbsp; «br» 
«/form» 
«/fieldset» 
</body> 
</html>"; 
} 
break; 
case 'textbox': 
if ($table) { 
$tablename=${'table '.$table}; 
$result=$db->query ("select content from $tablename where 
articleid='$articleid'"); 
if ($db->num rows ($result)==1){ 
$r-$db-»fetch array ($result); 
$content=$r [content]; 
} 
}else{ 
$content=''; 
} 
echo T 
<head> 
<title></title> 
<META HTTP-EQUIV='Pragma' CONTENT-'no-cache'» 
<meta http-equiv='Content-Type' content='text/html; charset=gb2312'> 
<LINK href=$rootpath/edit/site.css rel=stylesheet> 
</head> 
<body leftmargin='0' topmargin='0' marginwidth='0' marginheight='0'> 
"$content." 


</body> 
</html>"; 
break; 
case 'upspecialpic': 
if ($do) { 


if (empty ($userfile)){ 
exit (" 对 不 起 ,没有 上 传 文件 ! m; 

H 

if(Suserfile size--0)( 
exit ("对 不 起 , 上传 文 件 的 字 节 数 为 0! 7); 

} 

if(!is uploaded file($userfile))( 
exit (" 对 不 起 , 文件 上 传 失 败 ! m); 

H 

if($userfile size»$MAX FILE SIZE)( 
SMAX FILE SIZE-SMAX FILE SIZE/1000; 


exit ("对 不 起 , 你 上 传 的 文件 不 得 超过 $SMRAX FILE SIZE k! "); 


人 人 


上 
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$notuptypes-$notuptypes?$notuptypes:'.phpl.aspl.jspl.cgil|.dll'; 
if($type-file type($userfile name,$notuptypes))í( 
exit (" 对 不 起 ,请 不 要 上 传 ". $type. "格式 的 文件 ! n); 


$newfile-"./images/".$userfile name; 


createdir("./images"); 
$fileid-"asdfsdaf"; 
if (copy($userfile,S$newfile))( 
2> 
<script language='JavaScript'> 
Gu-- 
function Addfile(fileid)t( 


parent.document.forml.typepic.value-fileid; 
redirect ("editor.php?action-upspecialpic"); 


} 
function redirect(url) ( 
window.location.replace (url); 
) 
</SCRIPT> 


<script>setTimeout ("Addfile ('<?=$newfile?>');", 2);</script> 


<? $ 
exit; 

} 
?» 


10.4.4 系统 首页 


不 管 在 线 办 公 系 统 有 多 么 强大 的 功能 ， 首 页 功能 是 必 不 可 少 的 ， 如 图 10-5 为 凤 鸣 山 中 


小 学 校 在 线 办 公 系 统 的 首页 。 
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图 10-5 ”在 线 办 公 系统 首页 


下 面 通过 一 段 代 码 (index.php) 进 行 讲解 ， 具 体 如 下 : 


«?php 
function gettime ()// 获 得 时 间 


t 
$t = explode(" ",microtime()); 
return $t[1] + $t[0]; 
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$start = gettime(); 
// 开 始 缓冲 
ob start("ob gzhandler"); 
// 读 入 global 文件 
require './global.php'; 
// 是 否 显示 执行 时 间 
if ($showtime==0) $start-0; 
// 检 测 安装 文件 是 否 存在 
if((file exists('./install/install.php')) ( 
Qunlink('./install/install.php'); 
if((file exists('./install/install.php')) ( 
message('Please delete install.php via FTP!'); 
exit(); 
H 
} 
// 检 测 变量 防 sql 注入 
$ POST = sql injection($ POST); 
$ GET - sql injection($ GET); 
// 设 置 脚本 执行 时 间 为 600 秒 
Gset time limit(600); 
//'É session id 
//print r($ COOKIE); 
$sid-$ COOKIE['sid']; 
if($sid!-"") (session id($sid);] 
session start(); 
// 读 取 用 户 登录 的 ia 号 ,如果 不 存在 则 注销 这 个 变量 ; 
if (session is registered("user system id"))( 
$user system ids-$ SESSION["user system id"]; 
$user system ids-explode("|",$user system ids); 
$user id-$user system ids[0]; // 用 户 ia fü 
$system id-$user system ids[1]; // 系 统 id 值 
if ($system id!=1) { 
unset ($user system ids, $user id,$system id); 
showmessage ("对 不 起 你 已 经 登录 了 本 工作 室 开发 的 另 一 个 产品 ! <bt> 请 退出 该 产品 
","2filename-login"); 
) 
}else{ 
unset ($user system id, $user id,$system id); 


NH 
// 判 定 是 否 登录 过 
if($filename!-'login')( 
if (!isset ($user id)) $ GET['filename']-'login'; 


b 
// 设 置 管理 权限 
// 如 果 存 在 cookie 信息 则 读 取 cookie [group] 管 理 权限 信息 
if (isset($ COOKIE[group]l))( 
$group-explode("|", $ COOKIE[group]l):; 
$cookie id-$group[0]; // 用 户 id 值 
$group id-$group[1];  // 用 户 组 别 
$admin id-$group[2];  // 用 户 权 限 
$user name-$group[3]; // 用 户 姓名 
$real name-$group[4];  ”// 用 户 真实 姓名 


b 
// 检 测 是 否 存在 Suser_ idfü$cookie id 相等 ,如 果 不 等 则 重新 设置 cookie [group id] 管理 权 
限 信息 
if (($user id!-$cookie id) and isset ($user id))( 
$query-"select username,realname,groupid,admining from members where 


《人 r 


第 10 章 OA 在 线 办 公 系 统 


'userid'-'$user id' and 'groupid'«5 limit 1"; 
$result-$db-»query ($query); 
// 是 否 是 超级 管理 员 或 普通 管理 员 
if($db-»num rows ($result)--1)( 
$r-$db-»fetch array ($result); 


$cookie id-$user id; // 用 户 ia 
$user name-$r[username];  ”// 用 户 名 
$group id-$r[groupid]; // 用 户 组 


$admin id-$r[admining]; // 管 理 分 类 的 权限 
$real name-$r[realname]; // 用 户 真实 姓名 


setcookie("group","$cookie id|$group id|$admin id|$user name|$real 
name"); 
) 
} 
unset($cookie id); 
// 设 置 可 操作 的 文件 
$filename-$ GET['filename']; 
$filenames-array('index','left','header', 'main','deal','info','login','s 
etting','type','file','user','article','list','leave','calendar', 'schedu 
le','fileg','softdown','message','letter','table','favorite', 'classtable 
','show','soft down','ftp','userlist','blank','register','rmsoft','setva 
ruo qe regum 
$filename = empty ($filename) ? 'index' : $filename; 
// 操 作 记录 
getlog () 7 
// 初 始 化 变量 
$tpl-»assign (array('style'-»$style, 'rootpath'-»$rootpath, 'sitetitle'-» 
$sitetitle, 'school name'-»$school name)); 
// 读 取 相 应 文件 入 口 
if (in array ($filename, $filenames) ) { 
include once($admin root.'/'.$filename.'.php'); 
Jelse ( 
exit (" 你 所 操作 的 文件 不 存在 , 对 不 起 该 操作 不 可 执行 ! ") ; 
ji 
?» 


10.4.5 ”登录 管理 


如 果 用 户 需要 进入 系统 时 ， 当 输入 用 户 名 和 密码 后 ， 系 统 需 要 对 登录 数据 进行 验证 管 
理 。 登 录 信息 至 关 重要 ， 并 且 妥 善 的 保存 也 很 重要 ， 下 面 通过 一 段 代 码 (login.htmlphp) 进 行 
讲解 ， 具 体 如 下 : 


«html» 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=gbk" /> 
<title><?php echo $this->ftpl var['school name'];?»--«?php echo 
$this-»ftpl var['sitetitle'];?»«/title» 
«meta name-"keywords" content-"«?php echo $this-»ftpl var['keywords'];?»"» 
«meta name-"description" content-"«?php echo 
$this-»ftpl var['description'];?»"» 
<link rel="stylesheet" type="text/css" 
href=". /ext/resonrces/css/8xt-all.css^ /> 
<style type="text/css"> 
.user( background:url(./templates/test/images/user.gif) no-repeat 1px 
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2px; B 
-key{ background:url(./templates/test/images/key.gif) no-repeat lpx 
2px; } 
.key, -user{ background-color:#FFFFFF;  padding-left:20px; 
font-weight:bold; color:$000033; } 
«/style» 
</head> 
<body> 
<div id-"loading-mask" style=""> 
<div id="loading"> 
«div style="text-align:center;padding-top:26%"> 
«img src-"./templates/test/images/extanim32.gif" 
width-"32" height-"32" style-"margin-right:8px;" 
align-"absmiddle"/»Loading...«/div» 
«/div» 
«/div» 
«script type-"text/javascript" 
src-"./ext/adapter/ext/ext-base.js"»«/script» 
«script type-"text/javascript" src-"./ext/ext-all.js"»«/script» 
«script type-"text/javascript" src-"./ext/ext-lang-zh CN.js"»«/script» 
«script type-"text/javascript"» 
function reload() (window.location.reload();]) 
Ext.BLANK IMAGE URL = './ext/resources/images/default/s.gif'; 
Ext.QuickTips.init(); 
// 验 证 注册 密码 是 否 一 致 
Ext .apply (Ext .form.VTypes, { 
password: function (val, field) { 
if(field.confirmTo)( var pwd-Ext.get(field.confirmTo); return 
(val--pwd.getValue()); ) 
return true; 


) 

); 

Ext.onReady (function () { 
Ext.form.Field.prototype.msgTarget - 'side'; 
var store 1 = new Ext.data.SimpleStore(( 
fields:['title','value'], 
data:[[' 浏 览 器 进程 ', '0'],[' 保 留 一 大", 111, E P888 778,711] 

Es 
var staffForm = new Ext.FormPanel(( 

el:'hello-tabs', 
id:'staffForm', 
name:'staffForm', 
autoTabs:true, 
activeTab:0, 
deferredRender:false, 
border:false, 
items:( 
xtype:'tabpanel', 
activeTab: 0, 
defaults:(autoHeight:true, bodyStyle:'padding:1l0px'], 
items:[( 
title: ' HP Sx*', 
contentEl: 'loginInfo', 
layout:'form', 
defaults: (width: 230], 
defaultType: 'textfield', 
items: [{ 
lk MUSC 


fieldLabel: "账号 "， 
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name: 'username', 
style: 'font-size: 15px', 
allowBlank:false 
ht 
Css Ky 
fieldLabel: "密码 '， 
name: 'password', 
style: 'font-size: 15px', 
inputType: 'password', 
allowBlank:false 
ht 
fieldLabel: ' 验 证 码 '， 
name: 'chknumber', 
maxLength: 4, 
width: 100, 
style: 
'font-size:l4px; font-weight:bold; letter-spacing: 
lpx;background:url (chknumber.php) ;background-repeat: 
no-repeat;background-position: 50px Opx;center right no-repeat;', 
allowBlank:false 
),new Ext.form.ComboBox((í 
hiddenName:'cookietime', 
fieldLabel: ' 有 效 期 '， 
store:store 1, 
mode:'local', 
displayField:'title', 
valueField:'value', 
triggerAction:"all", 
editable:false, 
value:0, 
allowBlank:false, 
blankText: ' 请 选择 一 个 有 效 期 '， 
msgTarget:'qtip' 
n1 
Ist 
title: "关于 本 系统 "， 


LayouEs 


html: '«?php echo $this-»ftpl var['sitetitle'];?> 
«br» 开发 笔记 技术 支持 '， 
defaults: (border:false,width: 230} 
}] } H? 
var win = new Ext.Window ({ 
el:'hello-win', 
layout:'fit', 
width:490, 
height:300, 
//autoHeight:true, 
closeAction:'hide', 
plain: true, 
modal:true, 
collapsible: true, 
draggable: true, 
closable: true, 
items: 
staffForm, 
buttons: [t 
text: doe", 


handler: function (){ 
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if (win.getComponent ('staffForm').form.isValid())( 
win.getComponent ('staffForm') .form.submit ({ 
url:'index.php?filename-login&action-login', 
waitTitle: ' 提 示 '， 
method: 'POST', 
waitMsg: ' 正 在 登录 验证 ,请 稍 候 . . . '， 
success:function (form,action){ 
var loginResult = action.result.success; 
if(loginResult == false)( 
alert (action.result.message); 
) else if(loginResult -- true)( 
window.location.href-'./index.php'; 
) Fn 
failure: function(form,action) { 
//alert (' 登 录 系统 失败 ,请 与 管理 员 联系 .') ; 
Ext .MessageBox.alert (' 提 示 '，action.result.msg); 
win.getComponent ('staffForm').form.reset(); 
//alert (action.result.result); 
) H } Fin ys 
//Ext.get ('center-zone') 
win.show(); 
setTimeout(function() ( 
Ext.get('loading-mask').fadeOut( ( 
remove : true 
); 
), 250); 
); 
«/script» 
«div id-"hello-win" class-"x-hidden"» 
«div class-"x-window-header"»«?php echo $this-»ftpl var 
['school name'];?»--«?php echo $this-»ftpl var['sitetitle'];?»«/div» 
«div id-"hello-tabs"» 
«img src-"./templates/ 
«?php echo $this-»ftpl var['style'];?»/images/systemBanner.jpg"/» 
«/div» 
«div id-'loginInfo' style-'color:red;padding-left:120px;'» 
<br> 
<!-- 预 设 信息 ,位 入 登录 面板 下 面 一 行 --> 
请 输入 已 经 通过 审核 的 用 户 名 与 密码 进行 登录 ! ---[<a href-"./register.php" 
class=a><font color=blue><b> 单 击 注 册 </font></a>] 
</div> 
</div> 
<div id="swin" class="x-hidden"> 
<input id=dd type=text> 
</div> 
</body> 
</html> 


重复 代码 的 调用 
经 过 过 去 一 周 的 通宵 奋战 ,我 负责 的 框架 设计 工作 终于 全 部 完成 。OA 办 公 系 统 是 一 个 


超级 大 的 系统 ， 在 编写 程序 时 ， 不 要 只 为 了 功能 开发 而 开发 ， 要 编写 好 接口 ， 以 方便 第 二 


次 


T. 


发 。 把 一 些 常用 的 程序 写成 单独 的 代码 ， 这 些 重复 率 高 的 程序 只 需要 编写 一 次 就 可 以 
而 不 需要 多 次 编写 ， 做 无 用 功 ， 上 面 开发 了 系统 框架 设计 ， 主 要 包括 验证 码 、 注 册 、 


上 传 等 功能 ， 接 下 来 将 开发 日 常 办 公 的 常用 功能 。 
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10.5 日 常 办 公 的 常用 功能 


框架 设计 工作 完成 后 ， 接 下 来 项 目 进 入 了 第 四 个 阶段 一 一 办 公 常 用 功能 模块 的 编码 工 
作 。 此 模块 的 工作 是 由 TuanC 来 完成 的 ， 在 此 阶段 ， 他 需要 完成 如 下 几 个 方面 的 编码 工作 。 
拥有 自己 的 网 络 空间 
日 程 安排 
通讯 录 
课表 查询 
添加 文章 


10.5.1 拥有 自己 的 网 络 空间 

在 线 办 公 系 统 需要 给 普通 用 户 提供 一 个 网 络 空间 ， 这 样 能 方便 用 户 与 用 户 之 间 的 资料 
传递 ， 这 也 是 资源 共享 的 一 个 重要 的 方面 。 

1. 拥有 网 络 空间 


用 户 最 初 是 没有 网 络 空间 的 , 需要 用 户 注 册 并 经 管理 人 员 同 意 后 , 才能 拥有 ,如 图 10-6 
所 示 。 
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图 10-6 网 络 U 盘 页 面 


下 面 通过 一 段 代 码 cache/a/main.html 进行 讲解 ， 具 体 如 下 : 


<html> 

<head> 

<meta http-equiv='Content-Type' content='text/html; charset=gbk'> 
<title><?php echo $this->ftpl var['sitetitle'];?></title> 

<LINK href-"./templates/«?php echo $this->ftpl var['style'];?>/css/style.css" 
rel=stylesheet type=text/css> 
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<body  leftmargin-"0"  topmargin-"0" marginwidth="0"  marginheight-"0" 
Style-"background:£F8F8F0;"» 
«?php 
if($this-»ftpl var['action']--'new')( 
?» 
«table width-"100$" border-"0" cellpadding-"0" cellspacing-"0"» 
«!--DWLayoutTable--» 
«tr» «td height-"42" valign="top"> 
<TABLE width-"100$" border-0 align=center cellPadding-2 cellSpacing-1 
class-tableborder» 
«1!--DWLayoutTable--^ 
<TBODY> 
<TR> <TD valign=middle align=center bgcolor="#4466cc" class=submenu> 
</TD> 
</TR> <TR> <TD class=tablerow align=center valign=middle> 
</TD> </TR> </TBODY> </TABLE> </td></tr><tr><td> 
<TABLE cellPadding=2 cellSpacing=1 class=tableborder width="500" id=ftable> 
<tbody id-tbodyl» 
<TR> <td width="100%"> 
<a href="?filename=deal&action=newdisk&user name= 
<?php echo $this->ftpl var['user name'];?>&user id=<?php echo $this-> 
ftpl var['user id'];?>"> 单 击 这 里 开通 网 络 0 db, 你 的 u iA EA <?php echo 
$this->ftpl var['u size'];?»M«/a»«/td» 
«/TR»«/tbody»«/TABLE» «/td»«/tr»«tr» 
«td valign-"top"»«/td» «/tr» «/table» 
«?php 
Jelseif ($this-»ftpl var['action'] 
mo 
«script type-"text/javascript" src-"./include/ajax.js"»«/script» 
«table width-"760" border-"0" cellpadding-"0" cellspacing-"0" align=center> 
«!--DWLayoutTable--» 
«tr» 
«td valign="top"> 
<TABLE cellPadding-2 cellSpacing-1 width-"100$" > 
«1!--DWLayoutTable--» 
<TBODY> 
<TR> 
«Td height=24 valign=middle><b> 你 的 网 络 U 盘 容量 是 
<?php echo $this->ftpl var['u size'];?>M, 已 使 用 的 容量 : 
<?php echo $this->ftpl var['dirsize'];?></b></Td> 
</TR> </tbody> «/table» «/td» </tr> «tr»«td» 
<SCRIPT language-JavaScript» 
var aID-0; 
function ShowTabs1l (ID){ 
if (ID!-aID)( 
Tabsl[aID].style.display-"none"; 
Tabsl[ID].style.display-""; 
alID-ID; 
ix d 
function upfile()( 
window.open ("index.php?filename-swfupload&id- 
<?php echo $this-»ftpl var['id'];?»","newwindow","height-100, width=400, 
top-200, left-200, toolbar-no, menubar-no, scrollbars-no, 
resizable-no,location-no, status-no");] 
function upsfile() (window.open("index.php?filename-upload&id- 
«?php echo 
$this-»ftpl var['id'];?»","newwindow","height-100, width=400, top-200, 
left-200, 
toolbar-no, menubar-no, scrollbars-no, resizable-no,location-no, 


-'list')( 


[ 362 « ———————————————— ————————— HM - 


810€ OAZAAARH H 


status-no");] 
</SCRIPT> 
<table width="500" height="62" border="0" cellPadding=2 
cellSpacing-1 
class-tableborder» 
«1--DWLayoutTable--» 
«tr» 

«td width-"60" align="center" valign="middle" height-"40"» 
<a href-?filename-main&id-«?php echo $this-»ftpl var['uid'];?»» 
«img src-"./images/up.gif" alt=" 上 一 级 " width="32" height-"32" 
align="absmiddle" border=0 /></a></td> 
<td width="60" align="center" valign="middle"> 
«a href-?filename-main&id-0» 
«img src-"./images/home.gif" alt=" 根 目录 " 
width-"32" height-"32" align-"absmiddle" border-0 /»«/a»«/td» 
"60" align="center" valign-"middle"» 
#" onclick=ShowTabs1 (1);> 
./images/new folder.gif" width="32" height="32" align="absmiddle" 
border=0 /></a></td> 
<td width="60" align="center" valign="middle"> 
<a href="#" onclick-upsfile()»«img src-"./images/upload.gif" alt=" 上 传 " 
width-"32" height-"32" align-"absmiddle" border-0 /»«/a»«/td» 

«td width-"70" align="center" valign-"middle"» 
«a href-"$" onclick-upfile()» 
«img src-"./images/upload.gif" alt=" 上 传 大 文件 " width-"32" height-"32" 
align="absmiddle" border=0 /></a></td> 

<td width="60" align="center" valign="middle"><a href="#" 
onclick=cut ('fileall',0);> 
«img src-"./images/bcut.gif" alt=" 前 切 "” width-"32" height-"32" 
align="absmiddle" border=0 /></a></td> 

<td width="60" align="center" valign="middle"><a href=" 
onclick-paste(«?php echo $this->ftpl var['id'];?>, 
«?php echo $this-»ftpl var['layerid'];?>);> 
«img src-"./images/paste.gif" alt=" 粘 贴 " width-"32" height-"32" 
align-"absmiddle" border-0 /»«/a»«/td» 

«td width-"60" align-"center" valign-"middle"» 
«a href-"$" onclick-bzip();» 
«img src-"./images/bzip.jpg" alt=" 打 包 下 载 " width-"32" height-"32" 
align-"absmiddle" border-0 /»«/a»«/td» 

«td width-"150" rowspan-"2"» 

«/td» «/tr» «tr» 
«td height-"22" align-"center" valign-"middle" width="60"> 向 上 一 级 


</td> 
«td align="center" valign="middle" width="60"> 根 目录 </td> 
«td align="center" valign="middle" width="60"> 新 文件 夹 </td> 
«td align="center" valign="middle" width="60"> 上 传 文件 </td> 
«td align="center" valign="middle" width="70"><font color-red»«b» 
上 传 大 文件 </font></td> 
«td align-"center" valign-"middle" width="60"> 前 切 </td> 
«td align="center" valign="middle" width="60"> 粘 贴 </td> 
«td align-"center" valign-"middle" width="60"> 打 包 下 载 </td> 
«/tr» «/table»«/td»«/tr»«tr»«td» 
«table width-"100$" border-"0" cellpadding-"0" cellspacing-"0"» 
«!--DWLayoutTable--» 
<tbody style-"display:block" id-"Tabsl"» 
«tr» <td height-"20"» <div id-"msg"»«/div» 
«/td» «/tr» 
</tbody> 
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«tbody style-"display:none" id="Tabsl"> 
«tr» 
«form name-"forml" method="post" action-""» 
«td height-"20" > 文件 夹 名 称 : 
«input type-text name-foldername size-20 id-foldername» 
«input type-hidden name-id value- 
<?php echo $this-»ftpl var['id'];?»» 
«input type-hidden name-uid value- 
<?php echo $this-»ftpl var['uid'];?»» 
<input type=hidden name-layerid value= 
<?php echo $this->ftpl var['layerid'];?>> 
<input type=hidden name=cid> 
<input type=button name=ww value= 创 建文 件 夹 
onClick-"creatfolder()"» 


«/td» 
«/form» 
«/tr» 
</tbody> 
</table> 
«/td» 
«/tr» 
«tr» 


«td height-"24"» 
«TABLE cellPadding-2 cellSpacing-1 class-tableborder width-"500" id-ftable» 


<TR> 
«td width="5%"> 选 中 </td> 
<TD width="40%"> 名 称 </TD> 
«TD width="10%"> 大 小 </TD> 
«TD width="30%"> 更 新 时 间 </TD> 
«TD width="20%"> 操 作 </TD> 
</TR> 
<tbody id-tbodyl» 
<?php 
$ from = $this->ftpl var['content']; if (!is array($ from) 
&& !is object($ from)) ( settype($ from, 'array');] 
if (count($ from))( 
foreach ($ fromas $this-»ftpl var['keyid'] => $this-»ftpl var['cont'])( 
2 
<tr bgcolor="#F8F8F8" id=folder<?php echo $this->ftpl var['cont']['cid'];?»» 
<td><input type=checkbox name=checkfolder id=checkfolder 
value=<?php echo $this->ftpl var['cont']['cid'];?» disabled»«/td» 
<td><img src-./images/folder.gif border-0 alt= 文 件 夹 align-absmiddle» 
«a href-?filename-main&uid-«?php echo 
$this-»ftpl var['cont']['id'];?»&id- 
«?php echo 
$this-»ftpl var['cont']['cid'];?»»«?php echo 
$this-»ftpl var['cont']['foldername'];?»«/a»«/td» 
«td»-«/td» 
<td><?php echo $this-»ftpl var['cont']['addtime'];?»«/td» 
«td»«a href=# onClick-del ('ftable','folder«?php echo $this-» 
ftpl var['cont']['cid'];?»', 'folder',«?php echo $this-»ftpl var['cont']['cid'];?»)» 
«img src-./images/del.gif border-0 alt= 删 除 align-absmiddle»«/a» 
«a href-£ onClick-cut('folder', 
<?php echo $this-»ftpl var['cont']['cid'];?»)» 
«img src-./images/cut.gif border-0 alt= 前 切 align-absmiddle»«/a» «/td» 
«/tr» 
«?php 
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unset ($ form); 


ip m 

</tbody> 

<FORM name=form3 METHOD=POST action="" > 

<input type=hidden name=checkLines> 

<tbody id=tbody2> 

<?php 

$ from = $this->ftpl var['content2']; 

if (!is array($ from) && !is object($ from)) { settype($ from, 'array');} 

if (count($ from) ){ 

foreach ($ from as $this->ftpl var['keyid2'] => 
$this->ftpl var['cont2']){?> 

<tr bgcolor="#F8F8F8" id=file<?php echo $this->ftpl_var['cont2'] ['cid'];?>> 
<td><input type=checkbox name=checkLine id=checkLine 

value-«?php echo $this->ftpl var['cont2']['cid'];?»»«/td» 
<td><img src-./images/«?php echo $this-» 

ftpl var['cont2']['extend'];?».gif border-0 align-absmiddle alt=' 文 件 '> 

«a href-?filename-down&uid- 

<?php echo $this-»ftpl var['cont2']['id'];?»&id- 

<?php echo $this-»ftpl var['cont2']['cid'];?»» 

<?php echo $this-»ftpl var['cont2']['filename'];?»«/a»«/td» 
<td><?php echo $this-»ftpl var['cont2']['file size'];?»«/td» 
<td><?php echo $this-»ftpl var['cont2']['addtime'];?»«/td» 
<td><a href=# onClick-del('ftable','file«?php echo $this-» 

ftpl var['cont2']['cid'];?»','file',«?php echo $this-»ftpl var['cont2']['cid'];?»)» 

«img src-./images/del.gif border-0 alt= 删 除 align-absmiddle»«/a» 

«a href=# onClick-cut('file', 

<?php echo $this-»ftpl var['cont2']['cid'];?»)» 

«img src-./images/cut.gif border-0 alt= 前 切 align-absmiddle»«/a» «/td» 
«/tr» 

«?php) 

unset($ form); 
eme 


2. 用 户 上 传 功能 


当 用 户 拥 有 了 网 络 空间 后 ， 就 可 以 直接 向 服务 器 上 传 文件 了 ， 如 图 10-7 所 示 是 向 服务 
器 上 传 文件 的 界面 。 
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图 10-7 ”上传 文件 界面 
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下 面 通过 一 段 代码 (upload.php) 进 行 讲解 ， 具 体 如 下 : 


<?php 
function set path ($dir)// 设 置 路 径 
{ 
@fopen("./index.htm","a"); 
if (!is dir($dir)) 
t 
$temp = explode('/',$dir); 
$cur dir = ''; 
for($i-0;$i«count ($temp) ; $i++) 
i 
$cur dir .= $temp[$i].'/'; 
if (!is dir($cur dir)) 
{ 
Gmkdir($cur dir,0777); 
@fopen ("$cur dir/index.htm","a"); 
} 
b 
} 
return $cur dir; 
) 
$act-addslashes($ GET['action']);//VS Jg HT. 
$type-addslashes($ GET['uploadtype']);//2878 
if($act--'upload')( 
if(S$type--'attach')( 


$fileType-array('rar','zip','htm','doc','swf','fla','xls','html','txt', 
'jpg', 'gif', 'bmp', 'png', jpeg")7// 人 允许 上 传 的 文件 类 型 
) 
elseif ($type--'img')( 
$fileType-array('jpg', 'gif', 'bmp', 'png','jpeg'); 
) 
$year-date (Y); 
$upfileDir-"upload/teacher/$year/"; 
set path("../../".$upfileDir); 
$maxSize-50000; // 单 位 : KB 
$fileExt=substr (strrchr ($ FILES['filel']['name'], '.'),1); 
if(!in array(strtolower($fileExt),$fileType)) 
die ("<script>alert (' 不 允许 上 传 该 类 型 的 文件 ! 
$fileExt');window.parent.\$('divProcessing') .style.display='none'; 
history.back();</script>"); 
if($ FILES['filel']['size']» $maxSize*1024) 
die( "<script>alert (' 文 件 过 大 ! '); 
window.parent.\$ ('divProcessing') .style.display='none';history.back (); 
</script>"); 
if ($ FILES['filel']['error'] !=0) 
die ("<script>alert('" 未 知 错误 ,文件 上 传 失败 ! '); 
window.parent.$('divProcessing').style.display-'none';history.back(); 
</script>"); 
$targetDir-dirname( FILE ).'/../../'.$upfileDir; 
$targetFile-date('md').time().strrchr($ FILES['filel']['name'],'.'); 
$realFile-$targetDir.$targetFile; 
if(function exists('move uploaded file'))( 
move uploaded file($ FILES['filel']['tmp name'],$realFile); 
} 
else( 
Gcopy($ FILES['filel']['tmp name'],$realFile); 
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) 
if($type--'img')t( 


die("«script»window.parent.LoadIMG('../($upfileDir][$targetFile]'); 
</script>"); 

} 

elseif ($type--'attach')( 


die ("<script>window.parent .LoadAttach ('../{$upfileDir}{$targetFile}' 
M/seript> 
} 


?> 


10.5.2 ”短信 息 


短信 息 是 一 种 快捷 的 沟通 方式 ， 有 了 短信 息 功能 ， 免 去 了 打 电 话 或 者 当面 沟通 的 麻烦 ， 
可 以 通过 在 线 的 方式 实现 简短 的 沟通 ， 完 成 部 分 工作 。 界 面 如 图 10-8 所 示 。 
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图 10-8 短信 息 界 面 


下 面 通过 一 段 代 码 (message.html.php) 进 行 讲解 ， 具 体 如 下 : 


«html» 
<head> 
<meta http-equiv='Content-Type' content='text/html; charset=gb2312'> 
<title><?php echo $this->ftpl var['sitetitle'];?></title> 
<LINK href-"./templates/«?php echo 
$this-»ftpl var['style'];?»/css/style.css" rel=stylesheet type-text/css» 
<SCRIPT language-JavaScript» 
function check (theform)// 
{  if(theform.title.value == "") 1 
alert (" 请 输入 标题 !") ; 
theform.title.focus(); 
return false ; 
5 
return true ; 上 
function openurl (id)( 
window.open("index.php?filename-fileg&action-userdo&fileid-"-id,"newu"," 
height-200, width-200, top-200, left-200, toolbar-no, menubar-no, 
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Scrollbars-no, resizable-no,location-no, status=no");} 
</SCRIPT> 
<body leftmargin="0" topmargin="0" marginwidth="0" marginheight="0"> 
<table width="100%" border="0" cellpadding="0" cellspacing="0"> 

<!--DWLayoutTable--> <tr> 

«td width="100%" height="24" valign="top"> «TABLE width="100%" border=0 
align=center cellPadding=2 cellSpacing=1 
class=tableborder><!--DWLayoutTable--> 

<TR> 
<TD class=tablerow><B> 管 理 选 项 : </B> 

<A href-"?filename-message&action-receive&typeid- 
<?php echo $this-»ftpl var['typeid'];2>"> 收 件 箱 </R> | 
<A href-"?filename-message&action-send&typeid- 
<?php echo $this-»ftpl var['typeid'];?>"> 发 件 箱 </A> | 
<A href-"?filename-message&action-new&typeid- 
<?php echo $this-»ftpl var['typeid'];?>"> 新 建 短信 </A></td> 


</TR> </TBODY> </TABLE></td> 
«/tr» 
«tr» 
«td height="24"><strong> 当 前 位 置 >> 短信 箱 «/strong» «/td» 
</tr> 
<tr> 
<td height="309" valign="top"> 
<?php 
if ($this->ftpl var['action']--"new")( 
?» 


<TABLE cellPadding-2 cellSpacing-1 class-tableborder width-"100$" > 
«1!--DWLayoutTable--^ 
«form id-forml name-"forml" method="post" 
action-"?filename-deal&action-addmessage" OnSubmit-"return check (this)"» 
«Td colSpan-2 class-tr head height-28 align=center> 新 建 短 信 </Td> 
<TD class=tablerow> 标 题 </TD> 
<TD class=tablerow> 
<input type=text name="title" size=40> 
<FONT color=#ff0000>*</FONT> 
</TD> 
</TR> 
<TR> 
«TD class=tablerow> 内 </TD> 
<TD class=tablerow> 
<textarea name=content cols=60 rows=4></textarea> 
<FONT color=#ff0000>*</FONT> 
</TD> 
</TR> 
<TR> 
<TD class=tablerow> 收 信人 </TD> 
<TD class-tablerow» 
«input type-text name-"username" size-10»[«A 
href-"£dd" 


onclick-"window.open('index.php?filename-userlist&action-useradd 1', 
'new','height-180, width-200, top-200, left-100, toolbar-no, menubar-no, 
scrollbars-yes, resizable-no,location-no, status-no')"»«FONT 

color=green> 教 职工 名 单 </FONT></A>] 
</FONT> «FONT color=#f£f£f0000>*</FONT></td> 

«/TR» 
<TBODY> 
<TR> 


[ 368 | 人 s 


810€ OAZAAAR H 


<TD class-tablerow»&nbsp; </TD> 
<TD class=tablerow> 
<input type="submit" name-"Submit" value=" 发 送 "> 
&nbsp; «input type-"reset" name="Submitl" value=" 清除 "> 
</TD> 
</TR> 
</TBODY> 
</FORM> 
</TABLE> 
<?php 
H 
elseif(S$this-»ftpl var['action']--"receive")( 
?» 
XTABLE cellPadding-2 cellSpacing-1 width-"100$" > 
«1!--DWLayoutTable--^ 
«tr» 
«td width-"100$" > 
«table width-"100$" border: 
class-tableborder» 
«1!--DWLayoutTable--» 
«tr» 
«td width-"8$" valign-"middle" align-center height-32 
class=tr_head> 序 列 </td> 
«td width-"40$" valign-"middle" align-left class-tr head> 短 信 标 题 


0" cellpadding-"0" cellspacing-"0" 


«/td» 
«td width-"10$" valign="middle" align=center class-tr head> 发 信者 
«/td» 
«td width-"12$" valign="middle" align=center class-tr head> 发 送 日 期 
«/td» 
«/tr» 
«?php 


$ from = $this-»ftpl var['content']; if (!is array($ from) 
&& !is object($ from)) ( settype($ from, 'array');) 
if (count($ from) ) { 
foreach ($ fromas $this-»ftpl var['keyid'] => $this-»ftpl var['cont'])( 


?» 
«tr id-list«?php echo $this-»ftpl var['cont']['id'];?» 
valign-middle» 
«td align=center height=24 class-td2» 
<?php echo $this-»ftpl var['cont']['id'];?»«/td» 
«td align-center class-td2 title-" 
<?php echo $this-»ftpl var['cont']['content'];?»" 
><?php echo $this-»ftpl var['cont']['title'];?»«/td» 
«td align-center class-td2» 
<?php echo $this-»ftpl var['cont']['realname'];?»«/td» 
«td align-center class-td2» 
<?php echo $this-»ftpl var['cont']['sendtime'];?»«/td» 
</tr> 
«?php 


unset ($ form); 


<tr align="center" valign="middle"> 
<td class=tablerowhighlight> 
<?php echo $this-»ftpl var['pagenav'];?»«/td» 
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«/tr» 
</TABLE> 
<?php 
H 
elseif ($this->ftpl var['action']--"send")( 
2 
<TABLE cellPadding=2 cellSpacing=1 width="100%" > 
<!--DWLayoutTable--> 
«tr» 
«td width-"100$" > 


«table width-"100$" border-"0" cellpadding-"0" cellspacing-"0" 
class-tableborder» 
«1!--DWLayoutTable--^ 
«tr» 
«td width-"8$" valign="middle" align=center height=32 
class=tr_head> 序 列 </td> 
«td width-"40$" valign-"middle" align-left class-tr head> 短 信 标 题 


«/td» 
«td width-"10$" valign="middle" align=center class-tr head> 发 信者 
«/td» 
«td width-"12$" valign-"middle" align-center class-tr head> 发 送 日 期 
«/td» 
«/tr» 


«?php 
$ from = $this-»ftpl var['content']; if (!is array($ from) 
&& !is object($ from)) ( settype($ from, 'array');) 
if (count($ from))t 
foreach ($ from as $this-»ftpl var['keyid'] => $this-»ftpl var['cont']) 
?» i 
«tr id-list«?php echo $this->ftpl var['cont']['id'];?» 
valign-middle» 
«td align=center height=24 class-td2» 
<?php echo $this-»ftpl var['cont']['id'];?»«/td» 
«td align-center class-td2 title-" 
<?php echo $this-»ftpl var['cont']['content'];?»"» 
<?php echo $this-»ftpl var['cont']['title'];?»«/td» 
«td align-center class-td2» 
<?php echo $this-»ftpl var['cont']['realname'];?»«/td» 
«td align-center class-td2» 
<?php echo $this-»ftpl var['cont']['sendtime'];?»«/td» 
«/tr» «?php 
5 
unset($ form); 
| 2> 
</table> 
</td> 
</tr> 
<tr align="center" valign="middle"> 
<td class=tablerowhighlight> 
<?php echo $this-»ftpl var['pagenav'];?»«/td» 
«/tr» 
</TABLE> 
<?php 


</td> 
</tr> 
</table> 
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</body> 
«/html» 


10.5.3 ”日程 安排 


网 络 办 公 最 大 的 优点 就 是 在 很 短 的 时 间 内 知道 自己 要 做 什么 ， 并 且 用 很 短 的 时 间 将 其 
办 好 。 当 用 户 进入 系统 后 ， 如 果 有 工作 没有 完成 就 需要 显示 在 首页 ， 提 醒 用 户 完成 ， 如 
图 10-9 所 示 。 
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图 10-9 今日 工作 界面 


下 面 通过 一 段 代 码 cache/schedule.html.php 进行 讲解 ， 具 体 如 下 : 


<html> 
<head> 
«meta http-equiv-'Content-Type' content-'text/html; charset=gb2312'> 
«title»«?php echo $this-»ftpl var['sitetitle'];?»«/title» 
</head> 
<body leftmargin="0" topmargin="0" marginwidth="0" marginheight="0"> 
«table width-"100$" border-"0" cellpadding-"0" cellspacing="0"> 
«!--DWLayoutTable--» 
«tr» 
«td width-"100$" height-"24" valign="top"> 
<TABLE width-"100$" border-0 align=center cellPadding-2 cellSpacing-1 
class-tableborder» 
«1!--DWLayoutTable--^ 
<TBODY> 
<TR> 
<TD class=tablerow><B> 管 理 选项 : </B> <A 
href-"?filename-schedule&typeid- 


<?php echo $this-»ftpl var['typeid'];?»&action-d"»4 H LfE«/A» | «A 
href-"?filename-schedule&typeid-«?php echo 
$this-»ftpl var['typeid'];?>&action=w"> 本 周 安排 </A> | «A 


href-"?filename-schedule&typeid-«?php echo 

$this-»ftpl var['typeid'];?>&action=m"> 日 程 安排 查询 </A> | «a 
href-"?filename-schedule&typeid-«?php echo 

$this-»ftpl var['typeid'];?>&action=t"> 待 办 提醒 </a> | «a 
href-"?filename-schedule&typeid-«?php echo 

$this-»ftpl var['typeid']; ?2>&action=a"> 添 加 事务 </a></td> 
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</TR> 
</TBODY> 
</TABLE></td> 
< Nr 
«?php 
if(Sthis-»ftpl var['action']--'a')( 
?> 
<tr> 
<td height="24"><strong> 当 前 位 置 >> <?php echo 
$this-»ftpl var['now typename'];?» >> 添加 事务 </strong> </td> 
«ftr 
«tr» 
«td height-"309" valign="top"> 
<TABLE cellPadding-2 cellSpacing-1 class-tableborder width-"100$" > 
«1!--DWLayoutTable--^ 
«form id-forml name-" 
action-"?filename-deal&actio: 


forml" method="post" 
=addschedule" OnSubmit-"return check (this)" 


onReset-"return ResetForm();"» 
(日 期 格式 为 2007-4-23) * 如 果 没 有 则 不 提醒 , 提醒 日 期 要 早 于 开始 日 期 
*«/FONT»«/TD» 
«/TR» 
<TBODY> 
<TR> 


<TD class=tdrow>&nbsp; </TD> 
<TD class=tdrow> 
<input type="hidden" name=do value=1> 
<input type=hidden name=typeid value= 
<?php echo $this->ftpl_var['typeid'];?>> 
<input type="submit" name-"Submit" value=" 发 表 "> 
&nbsp; <input type="reset" name="Submitl" value=" 清 除 "></TD> 
</TR> 
</TBODY> 
</FORM> 
</TABLE></td> 
</tr> 
<?php 
} 
elseif ($this->ftpl var['action']=='d'){ 
?> 
<tr> 
<td height="24" ><strong> 当 前 位 置 > 
<?php echo $this-»ftpl var['now typename'];?» >> 今日 工作 </strong> </td> 
«table width-"100$" border-"0" cellpadding-"0" cellspacing-"0" 
class-tableborder» 
«!--DWLayoutTable--» 
«tr» 
«td width-"43" valign-"top" height-46» 
«table width-"100$" border-"0" cellpadding-"1" cellspacing-"0" 
background-"./templates/ 
<?php echo $this-»ftpl var['style'];?»/images/date-bg.gif"» 
«1--DWLayoutTable--» 
«tr» 
«td width-"43" height-"14" valign-"top" align-center» 
<?php echo $this-»ftpl var['cont']['date m'];?»/]«/td» 
«/tr» 
«tr» 
«td height-"32" valign="middle" align=center> 
<p style-"font-size: 16px ;color-red; "»«b» 
<?php echo $this-»ftpl var['cont']['date d'];?»«/b»«/p» 
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«/td» 
ut» 
«/table» 
«/td» 
«td valign-"middle"» 
«table width-"100$" border-"0" cellpadding-"0" cellspacing-"0"» 
«1--DWLayoutTable--» 
«tr» 
«td width-"100$" height-"26" valign-"middle" nowrap» 
«font color-$249624»«b» 
«b» [<?php echo $this-»ftpl var['cont']['title'];?»] 
«/b»«/font»«/td»«/tr» 
«tr» 
«td height-"1" valign-"niddle" bgcolor-"£A1C34D" > 
«/td» 
«/tr» 
<Er> 
<td height="19" valign="middle"> 
TAX] «a href="?filename=show&action=s&id= 
<?php echo $this->ftpl var['cont']['id'];?>" target-"- blank"> 
<?php echo $this->ftpl var['cont']['content'];?></a> 
</td> 
</tr> 
</table> 
</td> 
«/tr» 
</table> 
<table width-"100$" border-"0" cellpadding-"0" cellspacing="0"> 
«tr» 
«td height-"10" valign="middle" align=center> 
«/td» 
«/tr» 
</table> 
<?php 
} 
} 
else( 
unset($ form);?» 
今日 没有 事务 
«?php 


«/td» 
«/tr» 
«tr align="center" valign-"middle"» 
«td class-tablerowhighlight» 
<?php echo $this-»ftpl var['pagenav'];?»«/td» 
«/tr» 
</TABLE> 
</td> 
«/tr» 
«?php 
H 
elseif ($this->ftpl var['action']--'w')( 
?> 
«tr» 
«td height-"24" ><strong> 当 前 位 置 > 
<?php echo $this-»ftpl var['now typename'];?» >> 本 周 安排 </strong> </td> 
«/tr» 


——————————————————— 'PHàÀ >a 


^ 
V 深入 体验 PHP 项 目 开发 


«tr» 
«td height-"85" valign="top"> 
<TABLE cellPadding-2 cellSpacing-1 width-"100$" > 
«1!--DWLayoutTable--» 
«tr» 
«td width-"100$" » 
«table width-"100$" border-"0" cellpadding-"1" cellspacing-"1" 
class-tablel» 
«?php 
$ from = $this-»ftpl var['content']; if (!is array($ from) 
&& !is object($ from)) ( settype($ from, 'array');) 
if (count($ from))t 
foreach ($ fromas $this-»ftpl var['keyid'] => $this-»ftpl var['cont'])( 
?> 
<tr> 
<td valign="top" class=tdl height=100% width=60> 
«table width-"100$" border-"0" cellpadding-"1" cellspacing="0" 
height-100$» 
«1--DWLayoutTable--» 
«tr» 
«td nowrap align-center valign-middle class-tr head3 » 
<?php echo $this-»ftpl var['cont']['nowweek'];?»«/td» 
«/tr» 
</table> 
</td> 
<td width="43" class=tdl valign="top" height=46 align=center> 
«table width-"100$" border-"0" cellpadding-"1" cellspacing="0" 
background-"./templates/ 
<?php echo $this-»ftpl var['style'];?»/images/date-bg.gif" align=center> 


10.5.4 ”通讯 录 


通讯 录 是 网 络 办 公 系 统 中 必需 的 工作 资源 ， 它 可 以 让 你 很 快 地 找到 你 的 团队 成 员 ， 并 
完成 一 些 工 作 ， 如 图 10-10 所 示 为 通讯 录 界 面 效 果 。 
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A 10-10 通讯 录 界 面 
下 面 通过 一 段 代码 (letterhtml.php) 进 行 讲解 ， 具 体 如 下 : 
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< 


«td width-"100$" height="24" valign-"top"» «TABLE width-"100$" border=0 
align=center cellPadding-2 cellSpacing-1 class-tableborder» 
«!--DWLayoutTable--» 
<TBODY> <TR> 
<TD class=tablerow><B> 管 理 选 项 : </B> 
<A href-"?filename-letter&action-person&typeid- 
<?php echo $this-»ftpl var['typeid'];?>"> 个 人 通讯 录 </A> | 
<A href-"?filename-letter&action-public&typeid- 
<?php echo $this-»ftpl var['typeid'];?>"> 单 位 通讯 录 </A> 
| «A href-"?filename-letter&action-new&typeid- 
<?php echo $this->ftpl var['typeid'];?>"> 添 加 新 通讯 </A> | 
<a href="?filename=usergaction=infoedit"><font color=red> (点 这 里 修 
改 个 人 资料 ) </font></a> 
«/td» «/TR» </TBODY> 
«/TABLE»«/td» 
«/tr» «tr» «td height="24"><strong> 当 前 位 置 >> 
«?php echo $this-»ftpl var['now typename'];?» >> 新 建 通讯 </strong> 
«/td» 
eism SEES «td height-"309" valign="top"> 
<?php if(Sthis-»ftpl var['action']--"new")(?» 
<TABLE cellPadding-2 cellSpacing-1 class-tableborder width-"100$" > 
«1!--DWLayoutTable--» 
«form id-forml name-"forml" method="post" 
action-"?filename-deal&action-addletter" OnSubmit-"return check (this)"» 
<TBODY> 
<TR> 
«Td colSpan-2 class-tr head height=28 align=center> 新 建 通讯 </Td> 
«/TR» 
«TR» 
«TD class-tablerow»44 字 </TD> 
<TD class-tablerow» 
«input type-text name-"username" size-20» 
<FONT color-£ff0000»*«/FONT» 
«/TD» 
«/TR» 
<TR> 
<TD class=tablerow> 家 庭 地 址 </TD> 
<TD class-tablerow» 
«input type-text name-"address" size-40» 
«/TD» 
«/TR» 


«TR» 
«TD class=tablerow> 工 作 单 位 </TD> 
<TD class-tablerow» 
«input type-text name-"work" size-40» 
«/TD» 
</TR> 
<TR> 
<TD class=tablerow> 手 机 号 码 </TD> 
<TD class=tablerow> 
«input type-text name-"tell" size=20> 
</TD> 
«/TR» 
«TR» 
«TD class=tablerow> 小 灵通 </TD> 
XTD class=tablerow> 


————— —————— É——————— » 
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«input type-text name-"tel2" size=20> 
«/TD» 
</TR> 
<TR> 
<TD class=tablerow> 家 庭 电 话 </TD> 
<TD class=tablerow> 
<input type-text name-"tel3" size=20> 
</TD> 
</TR> 
<TR> 
<TD class=tablerow>QQ 号 码 </TD> 
<TD class-tablerow» 
«input type-text name-"qq" size-20» 
«/TD» 
</TR> 
<TR> 
<TD class=tablerow>email</TD> 
<TD class=tablerow> 
<input type=text name="email" size=20> 
</TD> 
</TR> 
<TR> 
<TD class=tablerow>msn</TD> 
<TD class=tablerow> 
<input type=text name="msn" size=20> 
</TD> 
</TR> 
<TBODY> 
<TR> 
<TD class=tablerow>&nbsp; </TD> 
<TD class=tablerow> 
<input type="submit" name-"Submit" value=" 发 送 " > 
&nbsp; <input type="reset" name="Submit1" value=" 清 除 "></TD> 
</TR> 
</TBODY> 
</FORM> 
</TABLE> 
<?php 
} 
elseif ($this->ftpl var['action']--"edit")( 
?» 
<TABLE cellPadding-2 cellSpacing-1 class-tableborder width-"100$" > 
«1!--DWLayoutTable--^ 
«form id-forml name-"forml" method="post" 
action-"?filename-deal&action-editletter" OnSubmit-"return check (this)"» 
<TBODY> 
<TR> 
«Td colSpan-2 class-tr head height=28 align=center> 新 建 通讯 </Td> 
</TR> 
<TR> 
<TD class=tablerow> 名 字 </TD> 
<TD class=tablerow> 
<input type=text name="username" size=20 value= 
<?php echo $this-»ftpl var['username'];?»» «FONT color=#ff0000>*</FONT> 
«/TD» 
</TR> 
<TR> 
<TD class=tablerow> 家 庭 地 址 </TD> 
XTD class=tablerow> 
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«input type-text name-"address" size-40 value- 
<?php echo $this-»ftpl var['address'];?»» 
«/TD» 
</TR> 
<TR> 
«TD class=tablerow> 工 作 单位 </TD> 
<TD class=tablerow> 
«input type-text name-"work" size-40 value- 
<?php echo $this-»ftpl var['work'];?»» 
«/TD» 
«/TR» 
«TR» 
«TD class=tablerow> 手 机 号 码 </TD> 
<TD class-tablerow» 
«input type-text name-"tell" size-20 value- 
<?php echo $this-»ftpl var['tell'];?»» 
«/TD» 
«/TR» 
«TR» 
«TD class=tablerow> 小 灵通 </TD> 
<TD class=tablerow> 
<input type=text name="tel2" size=20 value= 
<?php echo $this-»ftpl var['tel2'];?>> 
«/TD» 
«/TR» 
<TR> 
«TD class=tablerow> 家 庭 电 话 </TD> 
<TD class=tablerow> 
<input type=text name="tel3" size=20 value= 
<?php echo $this-»ftpl var['tel3'];?>> 
«/TD» 
</TR> 
<TR> 
«TD class-tablerow»QQ 号 码 </TD> 
<TD class-tablerow» 
«input type-text name-"qq" size-20 value- 
<?php echo $this-»ftpl var['qq'];?»» 
«/TD» 
</TR> 
<TR> 
<TD class=tablerow>email</TD> 
<TD class=tablerow> 
<input type=text name="email" size=20 value= 
<?php echo $this->ftpl var['email'];?>> 
</TD> 
</TR> 
<TR> 
<TD class=tablerow>msn</TD> 
<TD class=tablerow> 
<input type=text name="msn" size=20 value= 
<?php echo $this->ftpl_var['msn'];?>> 
</TD> 
</TR> 
<TBODY> 
<TR> 
<TD class=tablerow>&nbsp; </TD> 
<TD class=tablerow> 
<input type=hidden name=type value= 
<?php echo $this-»ftpl var['typeid'];?»» 


————————————————————— ——————" >60 


- 
V 
«input type 
<?php echo $this-»ftpl var 
«input type-" 
</TD> 
</TR> 
</TBODY> 
</FORM> 
</TABLE> 
<?php 
} 


elseif ($this->ftpl var['action'] 


po 


深入 体验 PHP 项 目 开发 。 于 


=hidden name=id value= 
pras 
submit" name-"Submit" value=" dj 4H " > 


--"person")( 


<TABLE cellPadding-2 cellSpacing-1 width-"100$" > 
«1!--DWLayoutTable--^ 


«tr» 
«td width-"100$" > 


«table width-"100$" border-"0" cellpadding-"0" cellspacing-"0" 


class-tableborder» 
«1!--DWLayoutTable--» 
«tr» 
«td width-"15$" 


class=tr_head> 姓 名 </td> 


val 


ign-"middle" align-center height-32 


«td width-"20$" valign="middle" align=center class=tr_head> 手 机 号 码 </td> 


«td width-"15$" 


valig 


middle" align=center class-tr head> 小 灵通 </td> 


«tdwidth-"12$" valign="middle" align=center class=tr head»QQ 号 码 </td> 


<td 
class-tr head»email«/td» 
«td width-"18$" vali 
«/tr» 
«?php 
$ from 


width-"20$" 


valign-"middle" align-center 


gn-"middle" align-center class-tr head> 操 作 </td> 


$this-»ftpl var['content']; if (!is array($ from) 


&& !is object ($ from)) ( settype($ from, 'array');) 


if (count ($ from))( 


foreach ($ fromas $this- 


?» 
«tr va 
«td 
<?php echo $this-»ftpl var 


«td 
<?php echo $this-»ftpl var 


«td align=center class-td2» 


<?php echo $this-»ftpl var 
«td align-center class-t: 
<?php echo $this-»ftpl var 
«td align-center class-t: 
<?php echo $this-»ftpl var 


»ftpl var['keyid'] => $this-»ftpl var['cont'])( 


lign-middle» 

align=center height=24 class-td2»«b» 
"cont']['username'];?»«/b»«/td» 
align-center class-td2» 
'cont']['tell'];?»«/td» 


"cont']['tel12'];?»«/td» 
d2» 
'cont']['qq'];?»«/td» 
d2» 
'cont']['email'];?»«/td» 


«td align=center class-td2»«a href=# onclick-show('list 


<?php echo $this-»ftpl var 


'cont'] ['id'];?»')»iffhi«/a» 


«a href-?filename-letter&typeid- 


<?php echo $this-»ftpl var 
<?php echo $this-»ftpl var 


'typeid'];?»&action-edit&id- 
'cont'] ['id'];?>> 编 辑 </a> 


«a href-index.php?filename-letter&action-del&id- 


<?php echo $this-»ftpl var 


'cont'] ['id'];?>> 删 除 </a></td> 


</tr> 
«tbody id-list 


<?php echo $this-»ftpl var 


'cont']['id'];?» style-display:none» 


«tr valign-middle » 
«td align=center height=24 class=td2><b> 家 庭 住址 </b></td> 
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«td align-left class-td2 colspan-2» 
<?php echo $this-»ftpl var['cont']['address'];?»«/td» 
«td align=center class=td2><b> 家 庭 电 话 </b></td> 
«td align-left class-td2 colspan-2» 
<?php echo $this-»ftpl var['cont']['tel3'];?»«/td» 
«/tr» 
«tr valign-middle» 
«td align-center height-24 class=td2><b> 单 位 地 址 
«/b»«/td» 
«td align-left class-td2 colspan-2» 
<?php echo $this-»ftpl var['cont']['work'];?»«/td» 
«td align=center class-td2»«b»msn«/b»«/td» 
«td align=left class-td2 colspan-2» 
<?php echo $this-»ftpl var['cont']['msn'];?»«/td» 
«/tr» 
«/tbody» 
«?php 


unset($ form); 


p owe 
</table> 
</td> 
</tr> 
<tr align="center" valign="middle"> 
«td class-tablerowhighlight»«?php echo $this->ftpl var['pagenav'];?»«/td» 
«/tr» 
</TABLE> 
<?php 
} 
elseif ($this->ftpl var['action']--"public")( 
?» 
<TABLE cellPadding-2 cellSpacing-1 width-"100$" > 
«!--DWLayoutTable--» 
<ET> 
<td width="100%" > 
<table width="100%" border="0" cellpadding="0" cellspacing="0" 
class=tableborder> 
<!--DWLayoutTable--> 
«tr» 
«td width-"15$" valign="middle" align=center height=32 
class=tr head> 姓 名 </td> 
«td width-"20$" valign-"middle" align-center class=tr head> 手 机 号 码 </td> 
«tdwidth-"15$" valign="middle" align=center class-tr head> 小 灵通 </td> 
«tdwidth-"12$" valign-"middle" align-center class=tr head>Q 号 码 </td> 
«td width-"20$" valign="middle" align-center 
class-tr head»email«/td» 
«td width-"18$" valign-"middle" align-center class-tr head> 操 作 </td> 
«/tr» 
«?php 
$ from = $this-»ftpl var['content']; if (!is array($ from) 
&& !is object($ from)) { settype($ from, 'array');] 
if (count($ from))( 
foreach ($ fromas $this-»ftpl var['keyid'] => $this-»ftpl var['cont'])( 
?» 


«tr valign-middle» 
«td align=center height=24 class-td2»«b» 
<?php echo $this-»ftpl var['cont']['realname'];?»«/b»«/td» 
«td align-center class-td2» 


—————————————————————— — » &a 
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<?php echo $this-»ftpl var['cont']['tell'];?»«/td» 

«td align-center class-td2» 

<?php echo $this-»ftpl var['cont']['tel2'];?»«/td» 

«td align=center class-td2»«?php echo $this-»ftpl var['cont']['qq'];?»«/td» 


«td align-center class-td2» 
<?php echo $this-»ftpl var['cont']['email'];?»«/td» 
«td  align-center  class-td2»«a href=#  onclick-show('list«?php echo 
$this-»ftpl var['cont']['id'];?»')»iffii«/a» </td> 

«/tr» 
«tbody id-list«?php echo $this-»ftpl var['cont']['id'];?» style-display:none» 

«tr valign-middle » 

«td align-center height-24 class-td2» 
<b> 家 庭 住 址 </b></td> 
«td align=left class-td2 colspan-2» 
<?php echo $this-»ftpl var['cont']['address'];?»«/td» 
«td align=center class=td2><b> 家 庭 电话 </b></td> 


«td align=left class-td2 colspan-2» 
<?php echo $this-»ftpl var['cont']['tel3'];?»«/td» 
«/tr» 
«tr valign-middle» 
«td align-center height-24 class=td2><b> 单 位 地 址 
</b></td> 
<td align=left class=td2 colspan=2> 
<?php echo $this->ftpl var['cont']['work'];?»«/td» 
«td align=center class-td2»«b»msn«/b»«/td» 
«td align=left class-td2 colspan-2»«?php echo $this-»ftpl var['cont'] ['msn'];?»«/td» 
«/tr» 
«/tbody» 
«?php 


unset ($ form); 


iege 
</table> 
«/td» 
«/tr» 
«tr align="center" valign-"middle"» 
«td class-tablerowhighlight»«?php echo $this-»ftpl var['pagenav'];?»«/td» 
«/tr» 
</TABLE> 
<?php 
} 
?» 
«/td» 
«/tr» 
</table> 
</body> 
</html> 


10.5.5 RREH 


此 OA 系统 是 为 学 校 教师 服务 的 办 公 系统 ， 每 一 位 教师 都 有 不 同 的 课程 安排 ， 所 以 课 
表 的 查询 是 十 分 重要 的 。 如 图 10-11 所 示 为 课表 查询 界面 。 
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10-11 ”课表 查询 界面 


下 面 通过 一 段 代 码 (selectshow.html php) 进 行 讲解 ， 具 体 如 下 : 


«html» 
«head» 
«meta http-equiv-'Content-Type' content-'text/html; charset-gbk'» 
«title»«?php echo $this-»ftpl var['sitetitle'];?»«/title» 
<LINK href-"./templates/ 
<?php echo  $this-»ftpl var['style'];?»/css/style.css" rel=stylesheet 
type=text/css> 
</head> 
<body leftmargin="0" topmargin="0" marginwidth="0" marginheight="0" 
style="margin: 0px;background: #F8F8F0; overflow:auto;"> 
<!--DWLayoutTable--> 
<?php 
if($this-»ftpl var['action']--"selectshow") (?» 
«table width-"100$" border-"0" cellpadding-"0" cellspacing-"0"» 
«!--DWLayoutTable--» 
<tr> <td valign="top"> 
<TABLE cellPadding=2 cellSpacing=1 width="100%" > 
<!--DWLayoutTable--> 
<tr> «td width-"100$" valign="top"> 
«table width-"100$" border-"0" cellpadding-"0" cellspacing-"0" 
class-tableborder» 
«1--DWLayoutTable--» 
«tr» «td width-"100$" valign="middle" align=center height=32 
class=tr head> 
<?php echo $this->ftpl var['selectyear'];?> 学 年 
<?php echo $this->ftpl var['classname'];?> 
<?php echo $this->ftpl var['teachername'];?» 
<?php echo $this->ftpl var['showtablename'];?> 课 程 表 
<font color=red> 
«a href-?filename-classtable&action-printtable&selectyear-«?php echo 
$this-»ftpl var['selectyear'];?»5&selectclass- 
<?php echo $this-»ftpl var['selectclass'];?»» (打印 课表 ) </a></font> 
«font color=red> 
«?php 
if($this-»ftpl var['usertype']--"c")(?» 
«a href-?filename-classtable&action-toword&usertype-c&do-l&selectyear- 
<?php echo $this-»ftpl var['selectyear'];?»&selectclass- 
«?php echo $this-»ftpl var 'selectclass'];?»» (fff € word) «/a»«/font»«/td» 


O—————— ————————Ó >B 
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«?php 
} 
else{?> 
«a href-?filename-classtable&action-toword&usertype-t&do-l&selectyear- 
<?php echo $this-»ftpl var['selectyear'];?»&selectclass- 
«?php echo $this-»ftpl var['teachername'];?»» (RIFE word)«/a»«/font»«/td» 
«?php 
H 
?» 
«/tr» 
«tr» 
«td width-"100$" valign="middle" align=center> 
«table width-"100$" border-"0" cellpadding-"0" cellspacing-"0" » 
<tr> 
<td width="100%" valign="middle" align=center colspan=2> 
<TABLE cellPadding-2 cellSpacing-1 class-tableborder 
width-"100$" > 
<TBODY> 
«tr» 
«td width-"10$" height-"32" align-"center" valign-"middle" 
class=tr_head> 星 期 </td> 
«td width=18% align="center" valign="middle" class-tr head> 星 期 一 </td> 
«td width=18% center" valign="middle" class=tr head> 星 期 二 </td> 
«td width=18% align="center" valign="middle" class=tr head> 星 期 三 </td> 
<td width=18% align="center" valign="middle" class=tr head> 星 期 四 </td> 
<td width=18% align="center" valign="middle" class=tr head> 星 期 五 </td> 
«/tr» 
«?php 
if($this-»ftpl var['usertype']--"t")( 
?» 


28" align-"center" valign-"middle" class-tr head2> 节 次 </td> 
«td align-"center" valign-"middle" class-tr head2> 课 名 /班级 </td> 
«td align="center" valign="middle" class=tr head2> 课 名 /班级 </td> 
«td align-"center" valign-"middle" class-tr head2> 课 名 /班级 </td> 
«td align-"center" valign-"middle" class-tr head2> 课 名 /班级 </td> 
«td align-"center" valign-"middle" class-tr head2> 课 名 /班级 </td> 
«/tr» 
«?php) 
else(?» 
«tr» 
"28" align-"center" valign-"middle" class-tr head2> 节 次 </td> 
"center" valign="middle" class=tr_head2> 课 名 /教师 </td> 
«td align-"center" valign-"middle" class-tr head2> 课 名 /教师 </td> 
«td align-"center" valign-"middle" class-tr head2> 课 名 /教师 </td> 
«td align-"center" valign-"middle" class-tr head2> 课 名 /教师 </td> 
«td align-"center" valign-"middle" class-tr head2> 课 名 /教师 </td> 
bn 
«?php)?» 
«?php 
$ from = $this-»ftpl var['classnum arr']; if (!is array($ from) 
&& !is object($ from)) { settype($ from, 'array');) 
if (count($ from))( 
foreach ($ fromas $this-»ftpl var['keyid'] => $this-»ftpl var['cont'])(?» 
«tr» 
«td height-"24" align-"center" valign-"middle" class-td2» 
<?php echo $this-»ftpl var['cont'];?»«/td» 
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«?php 
$ from = $Sthis-»ftpl var['week arr']; if (!is array($ from) 
&& !is object($ from)) { settype($ from, 'array');) 
if (count($ from))( 
foreach ($ from as $this-»ftpl var['keyid2'] => $this-»ftpl var['c'])(?» 
«td align-"center" valign-"middle" class-td2» 
<?php echo $this->ftpl var['name'] [$this->ftpl_var['keyid2']] [$this-> 
ftpl var['keyid']];?>/ 
<?php echo $this->ftpl var['classnum'] [$this->ftpl var['keyid2']][$this-> 
ftpl var['keyid']];?»«/td» 
<?php} 
unset ($ form); 
jus 
«/tr» 
«?php 


unset ($ form); 
] Ee 
«/TBODY» 


?» 
</body> 
</html> 


10.5.6 ”添加 文章 


本 OA 系统 有 添加 文章 的 功能 ， 用 户 可 以 通过 此 功能 发 表 各 种 文章 ， 如 图 10-12 所 示 为 
添加 文章 界面 。 
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10-12 ”添加 文章 界面 
下 面 通过 一 段 代码 (article.html.php) 进 行 讲解 ， 具 体 如 下 : 


<SCRIPT language-JavaScript» 
function ruselinkurl(){ 
if (document .forml .uselinkurl.checked==true){ 
document.forml.linkurl.disabled-false; 
article.style.display-'none'; 
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)else( 
document.forml.linkurl.disabled-true; 
article.style.display-''; 

lr 

function checktype () 
{H 
function check (theform) ( 
if (theform.title.value == "") { 
alert (" 请 填写 文章 标题 1") ; 
theform.title.focus(); 
return false ; } 
if (theform.teacherlist. pou 
if (theform.outtime.value-- 
alert (" 请 选择 事件 Mop my 
theform.outtime.focus(); 
return false ; 
p 
if(theform.typeid.value --0) { 
alert ("请 选择 版 块 !") ; 
theform.typeid.focus(); 
return false ; ) 
if(theform.manageid.value --0) 1 
alert (" 请 选择 部 门 !") ; 
theform.manageid.focus(); 
return false ; 


) 
return true; } 
function selDel( list ) ( 
var len = list.options.length; 
var idx = 0; 
while ( idx« len )( 
if ( list.options[idx].selected )( 
valuew-list.options[idx].value; 
list.options.remove (idx); 
len = list.options.length; 
rmsoft (valuew); 
) 


else( 
idx 4; 5 n 

function getHTTPObject () // 获 取 Http 请 求 对 象 , 这 个 对 象 用 于 客户 端 向 服务 端 发 送 异 步 
的 http 请 求 
{ 

var http; 

Var browser = navigator.appName; 
if(browser == "Microsoft Internet Explorer") { 


http = new ActiveXObject("Microsoft.XMLHTTP"); // 如 果 用 户 使 用 IE, 就 返回 
XMLHTTP 的 Activex 对 象 
} else 
{ http = new XMLHttpRequest(); // 否 则 返回 一 个 XMLHttpRequest 对 象 ) 
return http; } 
var http = getHTTPObject(); // 获 取 全 局 的 HTTP 请 求 对 象 
function getHello() // 处 理 请 求 状态 变化 
1 if (http.readyState == 4) //4 表示 请 求 已 完成 
日 
var helloStr = http.responseText; // 获 取 服 务 段 的 响应 文本 
// 插 入 响应 到 ID 为 ajax-sample 的 DIV 标签 内 
//document .getElementById ("ttt") .innerHTML = valuew+" 删 除 
"+hellostr; 


人 人 


9810€ OA 在 线 办 公 系 统 


] 
function rmsoft(valuew) ( 
var url - "?filename-rmsoft"; 
var ttttt-document.forml.addfile.value; 
var df-"softid-"-*valuew; 
http.open("POST", url, true); // 指 定 服务 端的 地 址 
// 定 义 传输 的 文件 HTTP 头 信息 


http.setRequestHeader ("Content-Type", "application/x-www-form-urlencoded" 
E 
http.send(df); // 发 送 变量 请 求 
http.onreadystatechange = getHello; // 请 求 状态 变化 时 的 处 理 函 数 
) 
</SCRIPT> 
</head> 
<body leftmargin="0" topmargin="0" marginwidth="0" marginheight="0"> 
<?php 
if ($this->ftpl_var['action']=='add'){ 
?> 
<table width="100%" border="0" cellpadding="0" cellspacing="0"> 
<!--DWLayoutTable--> 
«tr» 
«td height="24"><strong> 当 前 位 置 : 文章 管理 >> 文章 添加 </strong></td> 
«/tr» 
«tr» 
«td height-"309" valign="top"> 
<TABLE cellPadding-2 cellSpacing-1 class-tableborder width-"100$" > 
«1!--DWLayoutTable--» 


的 基本 功能 模块 


仅仅 耗 时 3 天 ，TunaC 的 编码 任务 就 全 部 完成 了 。 我 对 所 有 代码 浏览 一 遍 后 ， 得 出 一 
个 结论 : 在 开发 在 线 办 公 系统 时 ， 一 定 要 根据 人 们 办 公 特 点 开发 一 些 日 常 功能 ， 例 如 ， 拥 
有 一 定 的 网 络 空间 可 以 存储 自己 的 资料 ;为 方便 使 用 可 以 开发 一 个 短信 功能 ;通讯 录 的 功 
能 更 不 用 言说 ， 十 分 的 重要 。 对 于 学 校 的 老师 来 说 ， 课 表 也 是 十 分 重要 的 功能 之 一 ， 并 需 
要 因 人 而 异 。 


10.6 基本 管理 功能 


( 300108279, 8. — 

当 TuanC 在 进行 日 常 办 公 的 常用 功能 模块 的 编码 工作 时 ，TuanD 也 开始 了 他 的 基本 管 
理 功能 模块 的 编码 工作 。 此 阶段 他 需要 完成 以 下 5 个 方面 的 编码 工作 : 

(1) 部 门 管理 

(2) 栏目 操作 

(3) 用 户 管理 

(4) 学 生成 绩 管理 

(5) 页 面 设置 


T——— Ó————— OT ER >B 
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10.6.1 部门 管理 


在 一 个 学 校 里 ， 有 着 不 同 级 别 和 类 型 的 教职员 工 ， 他 们 身 处 不 同 部 门 ， 例 如 ， 有 的 在 
财务 部 门 ， 有 的 在 教学 部 门 等 ， 下 面 通 过 一 段 代码 (setting.php) 进 行 讲解 ， 具 体 如 下 : 

<?php 

if ($group id!=1) showmessage ("对 不 起 ,你 没有 权限 访问 ! "); 

?» 


<html xmlns-"http://www.w3.0rg/1999/xhtml" > 

«head» 

«meta http-equiv-"Content-Type" content-"text/html; charset-gbk" /» 
<title> 学 校 网 络 办 公 系 统 2009 v2.2.0«/title» 

<LINK href-"./templates/«?-$style;?»/css/style.css" rel=stylesheet 
type=text/css> 

</head> 

<? 

switch ($action) { 


case 'manage':// 部 门 管理 
switch ($do)( 
case 'edit' 
$action-"manageedit"; 
$sqgl-"select * from management where id-$id limit 1"; 
$r-$db-»query first ($sql); 
$manageid-$r[manageid]; 
$managename-$r [managename] ; 
$managetel-$r[managetel]; 
case 'add': 
if (l!isset($id))$action-"manageadd"; 


?> 
<body> 
<table width="100%" border="0" cellpadding="0" cellspacing="0"> 
<!--DWLayoutTable--> 
«tr» 
«td width-"100$" height-"42" valign="top"> 
«TABLE width-"100$" border-0 align=center cellPadding-2 cellSpacing-1 
class-tableborder» 
«1!--DWLayoutTable--» 
<TBODY> 
<TR> 
<TD align-middle bgcolor="#4466cc" class=submenu> 部 门 管理 </TD> 
«/TR» 
<TR> 
<TD class=tablerow><B> 管 理 选项 : </B> <A 
href="?filename=setting&gaction=manage&do=add"> 部 门 添加 </A> | «A 
href="?filename=settinggaction=manage&do=1ist"> 部 门 列表 </A> 
«/td» 
«/TR» 
«/TBODY» 
«/TABLE»«/td» 
«/tr» 
«tr» 
«td height="24"><strong> 当 前 位 置 : 部 门 管理 >> 部 门 添加 </strong> «/td» 
«/tr» 
«tr» 
«td height-"85" valign-"top"» 
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<TABLE cellPadding-2 cellSpacing-1 class-tableborder width-100$» 
<TBODY> 
<TR> 
«TH colSpan=2> 部 门 添加 </TH></TR> 
«form name-"forml" method="post" action-"?filename-deal"» 
«tr» 
«td width-"180" height-"25" align="right" bgcolor="#F0FOF0"> 部 门 id:«/td» 
<td bgcolor-"4F9F9F9"»«input name-"manageid" type="text" id-"manageid" 
size-"15" value-"«?-$manageid;?»"» </td> 
«/tr» 
En 
«td width-"180" height-"25" align="right" bgcolor="#F0F0F0"> 部 门 名称 
«/td» 
«td bgcolor-"£F9F9F9"»«input name-"managename" type="text" 
id-"managename" size-"15" value-"«?-$managename;?»"» </td> 
«/tr» 
Er 
«td width-"180" height-"25" align="right" bgcolor="#F0F0F0"> 部 门 电话 : 
«/td» 
<td bgcolor-"£F9F9F9"»«input name-"managetel" type="text" 
id-"managetel" size-"15" value-"«?-$managetel;?»"» £ AHHH; </td> 
«/tr» 
«tr» 
«td height-"25" align="right" bgcolor-"£FOFOF0"»&nbsp;«/td» 
«td bgcolor-"£F9F9F9"» 
«input type=hidden name-id value-«?-$id;?»» 
«input type=hidden name-action value-«?-$action;?»» 
<input type="submit" name-"Submit" value=" 确定 "> 
«/td» 
<? 
break; 
case 'list': 
// 分 页 设置 
$query-"select count(*) as num from management"; 
$r-$db-»query first ($query); 
$totalnum-$r [num]; 
$pagenumber = intval ($pagenumber); 
if (!isset($pagenumber) or $pagenumber--0) ($pagenumber-1;] 
S$curpage- ($pagenumber-1) *$perpage; 
$listurl-"?filename-setting&action-manage&do-list"; 
$pagenav-getpagenav ($totalnum, $1isturl); 
// 数 据 读 取 
$query="SELECT * FROM 'management' ORDER BY 'manageid' ASC limit 
$curpage, $perpage"; 
$result-$db-»query ($query) ; 
while ($s=$db->fetch array ($result) ){ 
$id=$s [id]; 
$manageid=$s [manageid]; 
$managename=$s [managename] ; 
$managetel-$s[managetel]; 
$list.-"«tr align=center> 
«td width-80 height=25 bgcolor-£FOF0F0» 
$manageid 
«/td» 
«td width=100  bgcolor-£FOFOF0» 
$managename 
«/td» 
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«td bgcolor-£F9F9F9» 
$managetel 
«/td» 
«td bgcolor-£F9F9F9 width-110» 
«a href-?filename-setting&action-manage&do-edit&id-$id» 


编辑 </a> 
«a href-?filename-setting&action-manage&do-del&id- 
$id> 删 除 </a> 
«/td» 
«/tr»"; 
) 

po 
«body» 


«table width-"100$" border-"0" cellpadding-"0" cellspacing-"0"» 
«!--DWLayoutTable--^ 
SETS 
<td width="993" height="42" valign="top"> 
<TABLE width-"100$" border-0 align=center cellPadding-2 cellSpacing-1 
class-tableborder» 
«1!--DWLayoutTable--» 
<TBODY> 
<TR> 
<TD align=middle bgcolor="#4466cc" class=submenu> 部 门 管理 </TD> 
«/TR» 
«TR» 
«TD class=tablerow><B> 管 理 选项 : </B> «A 
href="?filename=setting&action=manage&do=add"> 部 门 添加 </A> | «A 
href="?filename=setting&action=manage&do=1ist"> 部 门 列表 </A> 
</td> 
</TR> 
</TBODY> 
</TABLE></td> 
</tr> 
<tr> 
«td height="24"><strong> 当 前 位 置 部 门 管理 >> 编辑 部 门 </strong> «/td» 
«/tr» 
«tr» 
«td height-"85" valign="top"> 
<TABLE cellPadding-2 cellSpacing-1 class-tableborder width-100$» 
<TBODY> 
<TR> 
«TH»Y 列 </TH><TH> 部 门 名 称 </TH><TH> 部 门 电话 </TH><TH> 操 作 </TH></TR> 
«?-$1ist?» 
«?-$pagenav?» 
«/TBODY» 
</TABLE> 
</td> 
«/tr» 
</table> 
</body> 
«? 
break; 

Case el 
$referer-"?filename-deal&action-managedel&id-$id"; 
showmessage (" 是 否 删除 此 部 门 ", $referer, 'form'); 
break; 
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< 


case "group':// 用 户 组 别管 理 
switch ($do)( 
case 'edit': 
Saction-"groupedit"; 
$sqgl-"select * from usergroup where id-$id limit 1"; 
$r-$db-»query first ($sql); 
$groupid=$r [groupid] ; 
$grouptitle=$r [grouptitle]; 
$usize=$r[usize]; 
case. 'add': 
if (!isset ($id) )$action="groupadd"; 
pos 
«body» 
«table width-"100$" border-"0" cellpadding-"0" cellspacing-"0"» 
«!--DWLayoutTable--^ 
«tr» 
«td width-"100$" height-"42" valign="top"> 
<TABLE width-"100$" border-0 align=center cellPadding-2 cellSpacing-1 
class-tableborder» 
«1!--DWLayoutTable--» 
<TBODY> 
<TR> 
<TD align-middle bgcolor="#4466cc" class=submenu> 组 别管 理 </TD> 
</TR> 
<TR> 
«TD class=tablerow><B> 管 理 选项 : </B> «A 
href="?filename=setting&gaction=group&do=add"> 组 别 添加 </A> | «A 
href="?filename=setting&action=group&do=1ist"> 组 别 列表 </A> 
«td height="24"><strong> 当 前 位 置 : 组 别管 理 >> 组 别 添加 </strong> </td> 
<td height="85" valign="top"> 
<TABLE cellPadding-2 cellSpacing-1 class-tableborder width=100%> 
<TBODY> 
<TR> 
<TH colSpan=2> 用 户 组 添加 </TH></TR> 
<form name="forml" method="post" action="?filename=deal"> 
«tr» 
«td width-"180" height-"25" align="right" bgcolor="#FOFOF0"> 用 户 组 id: 
«/td» 
«td bgcolor="#F9F9F9"><input name-"groupid" type="text" id-"groupid" 
size="15" value-"«?-$groupid;?»"» </td> 
«td width-"180" height-"25" align="right" bgcolor="#FOFOF0"> 用 户 组 名 称 : 
«/td» 
«td bgcolor-"£F9F9F9"»«input name-"grouptitle" type-"text" 
id-"grouptitle" size-"15" value-"«?-$grouptitle;?»"» </td> 
«/tr» 
«tr» 
«td width-"180" height-"25" align="right" bgcolor-"£FOFOF0"»U AAE: 
«/td» 
«td  bgcolor-"$F9F9F9"»«input  name-"usize" type="text"  id-"isize" 
size-"15" value-"«?-$usize;?»"» </td> 
«/tr» 
«tr» 
«td height-"25" align="right" bgcolor-"£4FOFOF0"»&nbsp;«/td» 
«td bgcolor-"£F9F9F9"» 
«input type=hidden name-id value-«?-$id;?»» 
«input type=hidden name-action value-«?-$action;?»» 
«input type="submit" name-"Submit" value=" 确定 "> 
break; 
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case "1ist'": 
// 分 页 设置 
$query-"select count(*) as num from usergroup"; 
$r-$db-»query first ($query); 
$totalnum-$r[num]; 
$pagenumber = intval ($pagenumber); 
if (!isset($pagenumber) or $pagenumber--0) ($pagenumber-1;] 
$curpage- ($pagenumber-1) *$perpage; 
$listurl-"?filename-setting&action-group&do-list"; 
$pagenav-getpagenav ($totalnum, $1isturl); 
// 数 据 读 取 
$query-"SELECT * FROM 'usergroup' ORDER BY 'groupid' ASC limit 
$curpage, $perpage"; 
Sresult-$db-»query ($query); 
while ($s-$db-»fetch array($result))( 
$id-$s[id]; 
$groupid-$s[groupid]; 
$grouptitle-$s [grouptitle]; 
$usize-$s[usize]; 
$list.-"«tr align=center> 
«td width=80 height=25 bgcolor-£$FOFOF0» 
$groupid 
«/td» 
«td width=100  bgcolor-4FOF0F0» 
$grouptitle 
«/td» 
«td bgcolor-£F9F9F9» 
$usize 
«/td» 
«td bgcolor-4F9F9F9 > 
«a href-?filename-setting&action-right&groupid-$groupid» 


权限 设置 </a> 
«a href=?filename=setting&action=group&do=edit&id=$id> 编 辑 </a> 
«a href=?filename=setting&action=group&do=del&id=$id> 删 除 </a> 
«/td» 
</tr>"; 
} 
3> 
<body> 


«table width-"100$" border-"0" cellpadding-"0" cellspacing-"0"» 
«!--DWLayoutTable--» 
SETS 
<td width="993" height="42" valign="top"> 
<TABLE width-"100$" border=0 align=center cellPadding-2 cellSpacing=1 
class=tableborder> 
<!--DWLayoutTable--> 
<TBODY> 
<TR> 
<TD align-middle bgcolor="#4466cc" class=submenu> 组 别管 理 </TD> 
«/TR» 
<TR> 
<TD class=tablerow><B> 管 理 选项 : </B> «A 
href="?filename=settinggaction=group&do=adqd"> 组 别 添加 </A> | «A 
href="?filename=setting&action=group&do=1ist"> 组 别 列表 </A> 
</td> 
</TR> 
«/TBODY» 
X«/TABLE»«/td» 
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isis 
«tr» 
«td height="24"><strong> 当 前 位 置 : 组 别管 理 >> 编辑 组 别 </strong> «/td» 
LEES: 
«tr» 


<td height-"85" valign="top"> 
<TABLE cellPadding=2 cellSpacing-1 class=tableborder width=100%> 
<TBODY> 
<TR> 
«TH»Y 列 </TH><TH> 组 别名 称 </TH><TH>U 得 容量 </TH><TH> 操 作 </TH></TR> 
«?-$1ist?» 
«?-$pagenav?» 
«/TBODY» 
</TABLE> 
«/td» 
«/tr» 
</table> 
</body> 
<? 
break; 
case den 
$referer="?filename=deal&action=groupdel&id=$id"; 
showmessage ("是 否 删 除 此 组 别 "，, $referer, 'form'); 
break; 
) 
break; 
case 'subject' :// 学 科 管理 
switch ($do)( 
case 'edit': 
Saction-"subjectedit"; 
$sgl-"select * from subject where id-$id limit 1"; 
$r-$db-»query first ($sql); 
$subjectid-$r[subjectid]; 
$subjectname-$r[subjectname]; 
case 'add': 
if (l!isset($id))S$action-"subjectadd"; 
?» 
<body> 
<table width-"100$" border-"0" cellpadding-"0" cellspacing="0"> 
«1--DWLayoutTable--» 
«tr» 
«td width-"100$" height-"42" valign="top"> 
<TABLE width-"100$" border-0 align=center cellPadding-2 cellSpacing-1 
class-tableborder» 
«1!--DWLayoutTable--^ 


<TBODY> 
<TR> 
<TD align-middle bgcolor="#4466cc" class=submenu> 学 科 管 理 </TD> 
</TR> 
<TR> 


<TD class=tablerow><B> 管 理 选项 : </B> <A 
"2filename=settinggaction=subject&do=add"> 学 科 添 加 </A> | «A 


href: 
href="?filename=setting&action=subjectgdo=1ist"> 学 科 列 表 </RA> 
«/td» 
</TR> 
</TBODY> 
</TABLE></td> 
«/tr» 
«tr» 
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«td height="24"><strong> 当 前 位 置 : 学 科 管理 >> 学 科 添加 </strong> </td> 
«/tr» 
«tr» 
«td height-"85" valign-"top"» 
<TABLE cellPadding-2 cellSpacing-1 class-tableborder width-100$» 
<TBODY> 
<TR> 
<TH colSpan=2> 部 门 添加 </TH></TR> 
«form name-"forml" method="post" action-"?filename-deal"» 


«tr» 
«td width-"180" height-"25" align="right" bgcolor="#FOFOFO0"> 学 科 id:«/td» 
«td bgcolor-"£F9F9F9"»«input name-"subjectid" type-"text" 
id-"subjectid" size-"15" value-"«?-$subjectid;?»"» «/td» 
«/tr» 
«tr» 
«td width-"180" height-"25" align="right" bgcolor="#FOFOF0"> 学 科 名 称 : 
«/td» 
«td bgcolor-"£F9F9F9"»«input name-"subjectname" type-"text" 
id-"subjectname" size-"15" value-"«?-$subjectname;?»"» </td> 
«/tr» 
«tr» 


«td height-"25" align="right" bgcolor-"£FOFOF0"»&nbsp;«/td» 
«td bgcolor-"£F9F9F9"» 
«input type=hidden name-id value-«?-$id;?»» 
«input type=hidden name-action value-«?-$action;?»» 
<input type="submit" name-"Submit" value=" 确定 "> 
«/td» 
«/tr» 
«/form» 
«/TBODY» 
«/TABLE» 
«/td» 
«/tr» 
«/table» 
</body> 
<? 
break; 
case 'list': 
// 分 页 设置 
$query-"select count(*) as num from subject"; 
$r-$db-»query first ($query); 
$totalnum-$r [num]; 
$pagenumber = intval($pagenumber); 
if (!isset($pagenumber) or $pagenumber--0) ($pagenumber-1;] 
$curpage- ($pagenumber-1) *$perpage; 
$listurl-"?filename-setting&action-subject&do-list"; 
Spagenav-getpagenav ($totalnum,$1isturl); 
// 数 据 读 取 
$query-"SELECT * FROM 'subject' ORDER BY 'subjectid' ASC limit 
$curpage, $perpage"; 
$result=$db->query ($query); 
while($s=$db->fetch array ($result) ){ 
$id=$s[id]; 
$subjectid-$s[subjectid]; 
$subjectname-$s [subjectname]; 
$list.-"«tr align=center> 
«td width-80 height=25 bgcolor-£FOF0F0» 
$subjectid 
«/td» 
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«td width=100 bgcolor=#F0F0F0> 

$subjectname 

«/td» 

«td bgcolor-£F9F9F9 width-110» 

«a href-?filename-setting&action-subject&do-edit&id-$id» 


编辑 </a> 
«a href-?filename-setting&action-subject&do-del&id-$id» 
删除 </a> 
«/td» 
Enn 
J 

?> 
<body> 


<table width="100%" border="0" cellpadding="0" cellspacing="0"> 
<!--DWLayoutTable--> 
<tr> 
<td width="993" height="42" valign="top"> 
<TABLE width-"100$" border-0 align=center cellPadding-2 cellSpacing-1 
class-tableborder» 
«1!--DWLayoutTable--» 


<TBODY> 
<TR> 
<TD align-middle bgcolor="#4466cc" class=submenu> 学 科 管 理 </TD> 
</TR> 
<TR> 


«TD class=tablerow><B> 管 理 选项 : </B> «A 
href="?filename=setting&action=subject&do=adqd"> 学 科 添 加 </A> | «A 
href="?filename=setting&action=subject&do=1ist"> 学 科 列 表 </A> 
</td> 
</TR> 
</TBODY> 
</TABLE></td> 
</tr> 
<tr> 
«td height="24"><strong> 当 前 位 置 学 科 管 理 >> 编辑 学 科 </strong> «/td» 
«/tr» 
«tr» 
«td height-"85" valign="top"> 
<TABLE cellPadding-2 cellSpacing-1 class-tableborder width-100$» 
<TBODY> 
<TR> 
<TH> 序 列 </TH><TH> 学 科 名 称 </TH><TH> 操 作 </TH></TR> 
«?-$1ist?» 
«?-$pagenav?» 
cm 
break; 
case 'del': 
$referer-"?filename-deal&action-subjectdel&id-$id"; 
showmessage (" 是 否 删除 此 学 科 ", $Sreferer, 'form'); 
break; 
b 
break; 
case 'right': 
if ($groupid)( 
// 用 户 组 权限 读 取 
$sql="select * from userright where rightid-$groupid limit 1"; 
$result-$db-»query ($sql); 
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if($db->affected rows()!-0)( 
$r-$db-»fetch array ($result); 
$rights=$r [rights]; 
$right=1; 
$rights=explode (":",$rights); 
while (list ($key, $tright)=each ($rights)){ 
$tright=explode ("|",$tright); 
$lright=sizeof ($tright); 
for ($i=1;$i<=$lright; $i++) 
$rightdata[$tright[0]] []=$tright[$i]; 
) 
) else $right-0; 
) else $right-0; 
// 栏 目 数据 读 取 
$query-"SELECT * FROM $table type where isright-1 ORDER BY 'id' ASC 


$result-$db-»query ($query); 
$dd 
while ($r-$db-»fetch array($result))( 
Stypes.-$dd.$r[id]; 
if ($rightdata[$r[id]][0]--71) $islist-"checked"; 
if ($rightdata[$r[id]][l $isadd-"checked"; 
if ($rightdata[$r[id]][2 $isedit-"checked"; 
if ($rightdata[$r[id]][3 $isdel-"checked"; 
if ($rightdata[$r[id]][4]7-71) $ispass-"checked"; 
$rightlist.-" 
«tr align-center valign-middle» 
«td »$r[typename]«/td» 
«td»«input type-checkbox name-list$r[id] value-1 $islist»«/td» 
<td><input type-checkbox name-add$r[id] value-1 $isadd»«/td» 
<td><input type-checkbox name-edit$r[id] value-1 $isedit»«/td» 
<td><input type-checkbox name-del$r[id] value-1 $isdel»«/td» 
«td»«input type-checkbox name-pass$r[id] value-1 $ispass»«/td» 
«/tr» 


$dd-","; 
$islist-$isadd-$isedit-$isdel-$ispass-""; 
) 
unset ($islist,$isadd,$isedit,$isdel,$ispass); 
?> 
<body> 
«table width-"100$" border-"0" cellpadding-"0" cellspacing="0"> 
«!--DWLayoutTable--» 
«tr» 
«td height="24"><strong> 当 前 位 置 : 组 别管 理 >> 权限 管理 </strong> «/td» 
«/tr» 
«tr» 
«td height-"85" valign="top"> 
<TABLE cellPadding-2 cellSpacing-1 class-tableborder width-100$» 
<TBODY> 
<form name="forml" method="post" action-"?filename-deal&action-addright"» 
«TR» 
«TH» FE H 4 FK «/TH»«TE» 浏览 </TH><TH> 添加 </TH><TH> 编辑 </TH><TH> 删除 
</TH><TH> 审 批 </TH></TR> 
<?=$rightlist;?> 
«tr» 
«td align-center» 
«input type=hidden name-types value-"«?-$types;?»"» 
«input type=hidden name-right value-"«?-$right;?»"» 
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«input type=hidden name-groupid value-"«?-$groupid; ?»"» 
«input type-submit name-s value= 编 辑 权 限 ></td> 
«/tr» 
«/TBODY» 
</form> 
</TABLE> 
</td> 
«/tr» 
«/table» 
</body> 
<? 
break; 


case "classset':// 班 级 管理 
switch ($school type)t 
casai TEL 
$grade arr-array("1" 
n, mw4n=>" 小 四 年 级 ", "5"=>" 小 五 年 级 "， 
break; 
case ELS 
$grade arr=array ("1"=>" 初 一 年 级 ", "2"=>" 初 二 年 级 ", "3"=>" 初 三 年 级 


"小 一 年 级 "， "2"w=>" 小 二 年 级 ", "3"=>" 小 三 年 级 
"=>" 小 六 年 级 ") ; 


E 
break; 
case "31: 
$grade_arr=array ("1"=>" 高 一 年 级 ", "2"=>" 高 二 年 级 ", "3"=>" 高 三 年 级 
E 
break; 
case po 
Sgrade arr-array ("1"=>" 小 一 年 级 ", "2"=>" 小 二 年 级 ", "3"=>" 小 三 年 级 
mm4n=>" 小 四 年 级 ", "5"=>" 小 五 年 级 ", "6"=>" 小 六 年 级 ", "7T"=>" 初 一 年 级 ", "8"=>" 初 二 年 
级 ", "9gn"=>" 初 三 年 级 ") ; 


break; 


) 
foreach ($grade arr as $key-»$value) 
$grade.-"«option value-$key»$value«/option»"; 
switch ($do)( 
case 'edit': 
Saction-"classedit"; 
$sql-"select * from classset where id-$id limit 1"; 
$r-$db-»query first ($sql); 
$classid=$r [classid]; 
$noid=substr ($classid, 1,2); 
$classname=$r [classname] ; 
$gradeid-$r[gradeid]; 
$state-$r[state]; 
case 'add': 
if ('!isset(S$id)) ( 
$action-"classadd"; 
$gradeid-1; 
$noid-'01'; 


D 
<body> 
<table width="100%" border="0" cellpadding="0" cellspacing="0"> 
<!--DWLayoutTable--> 
«tr» 
«td width-"100$" height-"42" valign="top"> 
<TABLE width-"100$" border-0 align=center cellPadding-2 cellSpacing-1 
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class-tableborder» 
«!--DWLayoutTable--» 
<TBODY> 
<TR> 
«TD align-middle bgcolor="#4466cc" class=submenu> 班 级 管理 </TD> 
«/TR» 
«TR» 
«TD class=tablerow><B> 管 理 选项 : «/B» «A 
href="?filename=settinggaction=classset&do=add"> 班 级 添加 </A> | «A 
href="?filename=setting&gaction=classset&do=1ist"> 班 级 列表 </R> 
</td> 
«/TR» 
«/TBODY» 
«/TABLE»«/td» 
EE 
<tr> 
«td height="24"><strong> 当 前 位 置 : 班级 管理 >> 班级 添加 </strong> «/td» 
«/tr» 
«tr» 
«td height-"85" valign="top"> 
<TABLE cellPadding-2 cellSpacing-1 class-tableborder width-100$» 
<TBODY> 
<TR> 
<TH colSpan=2> 班 级 添加 </TH></TR> 
<form name="forml" method="post" action="?filename=deal"> 
<tr> 
«td width-"180" height-"25" align="right" bgcolor="#F0FOF0"> 所 在 年 级 : 
</td> 
«td bgcolor="#F9F9F9"> 
<select name=gradeid> 
«?-$grade;?» 
</select> 
<SCRIPT LANGUAGE-"JavaScriptl.2"» 
var Obj-document.forml.gradeid; 
Obj.value-"«?-$gradeid;?»"; 
</SCRIPT> 
<select name=noid> 
«option value='01'>1 班 </option> 
«option value='02'>2 班 </option> 
<option value='03'>3 班 </option> 
«option value-'04'»4 JE«/option» 
«option value-'05'»5 JE«/option» 
«option value-'06'»6 JE«/option» 
«option value-'07'»7 班 </option> 
«option value-'08'»58 JE«/option» 
«option value-'09'»9 JE«/option» 
«option value-'10'»10 班 </option> 
«option value-'11'»11 班 </option> 
«option value-'12'»12 班 </option> 
</select> 
<SCRIPT LANGUAGE-"JavaScriptl.2"» 
var Obj-document.forml.noid; 
0Obj.value-"«?-$noid;?»"; 
</SCRIPT> 
</td> 
p 
tg 


e - 
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«td height-"25" align="right" bgcolor-"£$FOÜFOF0"»&nbsp;«/td» 
«td bgcolor-"£F9F9F9"» 
«input type=hidden name-id value-«?-$id;?»» 
«input type=hidden name-action value-«?-$action;?»» 
<input type="submit" name-"Submit" value=" 确定 "> 
</body> 
<? 
break; 
人 
// 分 页 设置 
$query="select count(*) as num from classset"; 
$r-$db-»query first ($query); 
$totalnum-$r [num]; 
$pagenumber = intval($pagenumber); 
if (!isset($pagenumber) or $pagenumber--0) ($pagenumber-1;) 
$curpage- ($pagenumber-1) *$perpage; 
Slisturl-"?filename-setting&action-classset&do-list"; 
$pagenav-getpagenav ($totalnum, $1isturl); 
// 数 据 读 取 
$query-"SELECT * FROM 'classset' ORDER BY 'classid' ASC limit 
$curpage, $perpage"; 
$result-$db-»query ($query) ; 
while ($s=$db->fetch array ($result) ){ 
$id=$s [id]; 
$classid=$s [classid]; 
$classname-$s [classname] ; 
$list.="<tr align=center> 
<td width=80 height=25 bgcolor=#F0F0F0> 
$classid 
</td> 
<td width=100 bgcolor=#F0F0F0> 
$classname 
</td> 
<td bgcolor=#F9F9F9 width=110> 
«a href-?filename-setting&action-classset&do-edit&id-$id» 


编辑 </a> 

«a href-?filename-setting&action-classset&do-del&id-$id» 
删除 </a> 

</td> 

c d sa 
} 

?» 
«body» 


«table width-"100$" border-"0" cellpadding-"0" cellspacing-"0"» 
«!--DWLayoutTable--» 
«tr» 
«td width-"993" height-"42" valign="top"> 
«TABLE width-"100$" border-0 align=center cellPadding-2 cellSpacing-1 
class-tableborder» 
«1!--DWLayoutTable--» 
<TBODY> 
<TR> 
<TD align-middle bgcolor="#4466cc" class=submenu> 班 级 管理 </TD> 
«/TR» 
<TR> 
«TD class=tablerow><B> 管 理 选项 : </B> <A 
href="?filename=setting&gaction=classset&do=add"> 班 级 添加 </A> | «A 
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href="?filename=settinggaction=classset&gdo=1ist"> 班 级 列表 </A> 
«/td» 
</TR> 
</TBODY> 
</TABLE></td> 
«/tr» 
«tr» 
«td height="24"><strong> 当 前 位 置 : 班级 管理 >> 编辑 班级 </strong> «/td» 
«/tr» 
«tr» 
«td height-"85" valign="top"> 
<TABLE cellPadding-2 cellSpacing-1 class-tableborder width-100$» 
<TBODY> 
<TR> 
<TH> 班 级 编号 </TH><TH> 班 级 名 称 </TH><TH> 操 作 </TH></TR> 
<?=$list?> 
<?=$pagenav?> 


</TBODY> 
</TABLE> 
</td> 
«/tr» 
</table> 
</body> 
2 
break; 
case "del's 
$referer-"?filename-deal&action-classdel&id-$id"; 
showmessage (" 是 否 删除 此 班级 ", $Sreferer, 'form'); 
break; 
) 
break; 
) 
?» 


10.6.2 栏目 操作 


在 线 办 公 的 操作 系统 需要 对 栏目 进行 操作 ， 例 如 ， 栏 目 设置 、 添 加 编辑 、 参 数 设置 、 
分 页 设置 等 ， 下 面 通过 一 段 代码 (fileg.php) 进 行 讲解 ， 具 体 如 下 : 
«?php 
/* 
凤 鸣 山 中 小 学 网 络 办 公 室 
v 
// 栏 目 数据 读 取 
if ($typeid)t 
$query-"select typename from $table type where 'id'-'$typeid' limit 1"; 
$r-$db-»query first ($query); 
$now typename-$r[typename]; 
Jelse ( 
$now _ typename=" 全 部 文章 "; 
) 
$tpl-»assign("now typename",$now typename); 
if ($action--"")$action-"list"; 
switch ($action) { 
// 添 加 编辑 操作 


case "add": 


人 
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break; 
// 文 件 柜 列表 
case 'list': 
// 参 数 设置 
$nowday=mktime (0,0,0,date (m) , date (d) , date (Y)) ; 
// 分 页 设置 
$query="select count(*) as num from $table file where 
inputer-$user id"; 
$r-$db-»query first ($query); 
S$totalnum-$r [num]; 
$pagenumber = intval ($pagenumber); 
if (!isset(Spagenumber) or $pagenumber--0) ($pagenumber-1;) 
$curpage- ($pagenumber-1) *$perpage; 
$pagenav-getpagenav ($totalnum, $1isturl); 
// 相 应 版 块 数据 读 取 
$query="select $table file.*,members.realname 
from $table file 
left join members on $table file.sender-members.userid 
where inputer-$user id 
order by intime desc 
limit $curpage,S$perpage"; 
$result-$db-»query ($query) ; 
while ($r=$db->fetch array ($result) ){ 


$intime=date ("Y/m/d",$r[intime]); 
$content []=array ("id"=>$r [id] , "title"=>$r[title], "realname"=> 
$r[realname], "intime"-»$intime, "hash"=>$r[hash]); 
} 
$tpl-»assign('pagenav',$pagenav); 
$tpl-»assign('content',$content); 
if (!$content) Scontent=" 今 日 没有 事务 ! "; 
break; 
// 删 除 文件 
case 'filedel': 
showmessage (" 是 否 删除 此 文件 "， $url forward = "?filename- 
deal&action-filedel&fileid-$fileid&hash-Shash", $msgtype = 'form'); 
break; 
// 发 文件 给 其 他 用 户 
case 'userdo': 
// 读 取 用 户 组 
$query-"select * from usergroup order by groupid"; 
$result-$db-»query ($query); 
while ($r-$db-»fetch array ($result) ){ 
$showgroup.-"«option value-'$r[groupid] '»$r[grouptitle]«/option»"; 


H 

// 读 取 部 门 信息 

$query-"select * from management order by manageid"; 

$result=$db->query ($query); 

while($r-$db-»fetch array ($result)){ 
$managements [$r [manageid]]-$r[managename] ; 
$showmanage.="<option value=' $r [manageid] '»$r|[managename] «/option»"; 

H 

// 读 取 学 科 信息 

$query-"select * from subject order by subjectid"; 

$result=$db->query ($query); 

while($r-$db-»fetch array ($result)){ 
$showsubject .="<option 

value-'$r[subjectid]'»$r[subjectname]«/option»"; 
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} 

// 设 置 数据 

while (list($key,$value)=each ($managements) ) { 
$managementlist.="<option value=$key>$value</option>"; 

} 

if ($manageid){ 
$query="SELECT * FROM 'members' where manageid=$manageid"; 
$result=$db->query ($query) ; 
while ($r=$db->fetch array ($result) ){ 

$userlist.= "<option value=$r [userid]>$r [realname]</option>"; 

} 

} 


$tpl->assign (array ("fileid"=>$fileid, "userlist"=>$userlist, 'manageid 
US 
$manageid, "managementlist"—-»$managementlist, "showsubject"-»$showsubject)); 
break; 
) 
$tpl-»assign('action',$action); 
$tpl-»display('fileg.html'); 
Eo 


10.6.3 APEH 


在 OA 办 公 系 统 里 ， 每 一 个 老师 都 是 一 个 用 户 ， 整 个 系统 中 有 着 各 种 角色 的 用 户 。 在 
线 办 公 系 统 需要 对 这 些 用 户 进行 管理 ,下 面 通过 一 段 代 码 (userlistphp) 进 行 讲解 ， 具体 如 下 : 

«?php 

// 读 取 用 户 组 

$query-"select * from usergroup order by groupid"; 

$result-$db-»query ($query); 

while($r-$db-»fetch array ($result)){ 

$showgroup.-"«option value-'$r[groupid]'»$r[grouptitle]«/option»"; 


) 
// 读 取 部 门 信息 
$query-"select * from management order by manageid"; 
$result-$db-»query ($query) ; 
while ($r-$db-»fetch array ($result)){ 
$managements [$r [manageid]]-$r[managename] ; 
$showmanage.-"«option value-'$r[manageid]'»$r[managename]«/option»";] 
// 读 取 学 科 信息 
$query-"select * from subject order by subjectid"; 
$result-$db-»query ($query); 
while($r-$db-»fetch array($result))( 
$showsubject.-"«option 
value-'$r[subjectid]'»$r[subjectname]«/option»";) 
Switch ($action)( 
case 'useradd': 
case 'useradd 1': 
case 'useradd 2': 
case 'userdel': 
default: 
// 设 置 数据 
while (list ($key, $value)=each ($managements)) ( 
$managementlist.-"«option value-$key»$value«/option»"; 
}if ($manageid)( 
$query-"SELECT * FROM 'members' where manageid-$manageid"; 
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$result=$db->query ($query) ; 
while ($r=$db->fetch array ($result) ){ 
$userlist.= "<option 
value-$r[userid]»$r[realname]«/option»"; 
) 
} 
$tpl-»assign (array ('manageid'-»$manageid, 'managementlist'=> 
$managementlist,'userlist'-»$userlist)); 
break; 
} 
$tpl-»assign('action',$action); 
$tpl-»display('userlist.html'); 
?» 


10.6.4 学 生成 绩 管 理 


在 这 个 系统 里 ， 学 生成 绩 当 然 是 至 关 重 要 的 ， 需 要 一 些 老师 在 应 有 的 权限 内 ， 将 成 绩 
上 传 上 去 ， 供 整个 系统 使 用 ， 下 面 通过 一 段 代码 (result.php) 进 行 讲解 ， 具 体 如 下 : 


<?php 
// 模 板 初始 化 
$templatesused.="result, result up,footer"; 
cachetemplates ($templatesused); 
Switch ($action) { 
case 'insert': 
// 读 取 文 件 信息 并 显示 出 来 
require ("./include/file class.php"); 
$updir-"./attach/$class id/"; 
$filepath-"$updir$fileid"; 
M SBE EL 
$fl = new File class; 
$fl-»file-$filepath; 
$h-$fl-»getlines(); 
$line-$fl-»read file(); 
for ($i=0;$i<$h;$i++){ 
$out-explode("|", $line[$i]):; 
//$student data=$i;// 数 据 传递 方法 一 
// 数 据 传递 方法 二 
$result data-trim(S$out[0])."|".trim(Sout[1]) ."|".trim(Sout[2]) ."|". 
trim($out[3]) ."|".trim($out[4]) . "| "| trim($out [5]) . "|". trim($out[6]) ."|". 
trim($out[7]); 
$result list.-"«tr align-center» 
«td height=24 class-tdl»«input type-V"checkbox V" 
name-W'stdataV" value-W'$result data\"> </td> 
«td  class-tdl»".$i."«/td» 
«td class-tdl1»".trim($out[0])."«/td» 
«td class-tdl»".trim($out[1])."«/td» 
«td class-tdl»".trim($out[2])."«/td» 
<td class-tdi»"-trim(Sout[3])."c/td» 
«td class-tdl»".trim($out[4]) ."«/td» 
«td class-tdl»".trim($out[5])."«/td» 
«td class-tdl»".trim($out[6])."«/td» 
«td class-tdl»".trim($out[7])."«/td» 
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$head nav=" 学 生成 绩 管理 "; 
$admin nav="<A href-V"?filename-result&action-upV "> 学 生成 绩 上 传 </A> | 
«A href=\"?filename=result&action=in\"> 学 生成 绩 入 库 </A> | 
«A href=\"?filename=result&action=1ist\"> 学 生成 绩 列表 </A> 
$now_nav=" 学 生成 绩 上 传 "; 
eval ("\$result list = \"".gettemplate('result insert')."N";"); 
$templatetitle="result"; 
break; 
case 'in': 
// 读 取 目 录 里 面 上 传 的 文件 
$updir="./attach/$class id/"; 
$handle-opendir ($updir); 
$i-1; 
while (false !== ($file = readdir($handle))) ( 
$i++; 
if (($file==".") or ($file=="..") or ($file=="index.htm")) continue; 
$filename=explode (".", $file); 
$filename=$filename[0]; 
$list file.="<tr bgColor=\"#f1f3f5\" 
onmouseout=\"this.style.backgroundColor='#F1F3F5'\" 
onmouseover=\"this.style.backgroundColor="'#BFDFFF'\"> 
<td align=center height=24 width=80> 
<input type=button name=aa value= 删 除 
onclick-delfile('./data/$file')» 
«/td» 
«td align-left» 
«a 
href-?filename-result&action-insert&fileid-$file»$file«/a» 
«/td» 
«/tr» 


"e 
; 


} 

closedir ($handle); 

$head nav=" 学 生成 绩 管理 "; 

$admin nav="<A href=\"?filename=result&action=up\"> 学 生成 绩 上 传 </A> | 
«A href=\"?filename=resultgaction=in\"> 学 生成 绩 入 库 </A> | 
«A href=\"?filename=result&action=1ist\"> 学 生成 绩 列表 </A> 
". 

$now_nav=" 学 生成 绩 入 库 "; 

eval ("\$result list = \"".gettemplate('result in')."\ 

$templatetitle="result"; 

break; 

case 'up': 

$heaqd_nav=" 学 生成 绩 管理 "; 

$admin nav="<A href=\"?filename=result&action=up\"> 学 生成 绩 上 传 </A> | 
«A href=\"?filename=result&action=in\"> 学 生成 绩 入 库 </A> | 
«A href=\"?filename=result&gaction=1ist\"> 学 生成 绩 列表 </A> 

$now_nav=" 学 生成 绩 上 传 "; 

eval ("\$result list = \"".gettemplate('result up')."\";"); 

$templatetitle="result"; 

break; 

// 本 班 学 生成 绩 列表 

case 'list': 

// 页 码 设置 开始 

$sql = "SELECT count(*) FROM $table result where 'stnumber'-' $class id' m 
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$result = $db-»query first ($sql); 
$totalnum=$result[0]; 
$pagenumber = intval ($pagenumber); 
if (!isset($pagenumber) or $pagenumber--0) ($pagenumber-1;] 
$curpage- ($pagenumber-1) *$perpage; 
$pagenav-getpagenav ($totalnum, "?filename-result&action-list"); 
// 页 码 设置 结束 
// 记 录 数 据 的 读 取 
$i-1; 
$class style-"td1l"; 
$query-"select * from $table result 
where 'stnumber'-'$class id' 
order by id DESC limit $curpage,$perpage"; 
$result-$db-»query ($query); 
while($r-$db-»fetch array($result))( 
Sintime-date ("Y/m/d",$r[intime]); 
$result list.-" 

«tr id-list$r[id] valign-middle» 

«td align-center height-24 
class-$class style»$r[id]«/td» 

«td align-center class-$class style» 
«a href-WV"?filename-result&action-listone&id-$r[id]V"»$r[note]«/a»«/td» 

«td align-center class-$class style>$intime</td> 

«td align-center class-$class style» 

«a href-A"?filename-result&action-listone&id-$r[id]N" > 查看 </a> | «a 
href-A"?filename-result&action-delone&id-$r [id] \">M</a></td> 


«/tr» 
T 
if ($class style--"tdl") $class style-"td2";else 
$class style-"tdl"; 
) 
$heaqd_nav=" 学 生成 绩 管理 "; 
$admin nav="<A href=\"?filename=result&action=up\"> 学 生成 绩 上 传 </A> | 
«A href=\"?filename=resultgaction=in\"> 学 生成 绩 入 库 </A> | 
«A href=\"?filename=result&action=1ist\"> 学 生成 绩 列表 </A> 
". 
$now_nav=" 学 生成 绩 列表 "; 
eval ("\$result list = \"".gettemplate('result list')." 
$templatetitle-"result"; 
break; 
// 本 班 学 生 具体 成 绩 列表 
case 'listone': 
// 记 录 数 据 的 读 取 
$i-1; 
$class style-"tdl"; 
$sql = "SELECT count(*) FROM $table result where averageid-$id"; 
$result = $db-»query first ($sql); 
$totalnum-$result[0]; 
$query-"select $table result.*,$table student.name from $table result 
LEFT JOIN $table student ON 
$table result.stnumber-$table student.stnumber 
where $table result.averageid-'$id' 
order by $table result.id limit 0,$totalnum"; 
$result=$db->query ($query); 
while ($r=$db->fetch array($result))( 
$intime=date ("Y/m/d",$r[intime]); 
$result list.-" 
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«tr id-list$r[id] valign=middle> 
«td align-center height-24 

class-$class style»$r[stnumber]«/td» 
«td align=center class-$class style»$r[name]«/td» 
«td align=center class-$class style»$r[yw]«/td» 
«td align-center class-$class style»$r[sx]«/td» 
«td align=center class-$class style»$r[wy]«/td» 
«td align=center class-$class style»$r[kx]«/td» 
«td align-center class-$class style»$r[sz]«/td» 
«td align=center class-$class style»$r[l1s]«/td» 

«td align-center class-$class style» 
«a href=\"#\"” > 修改 </a> </td> </tr> 


mm 
if ($class style--"tdl") $class style-"td2"; 

else $class style-"tdl"; 

) 

$head nav=" 学 生成 绩 管理 "; 

$admin nav-"«A href=\"?filename=result&action=up\"> 学 生成 绩 上 传 </A> | 
«A href=\"?filename=result&action=in\"> 学 生成 绩 入 库 </A> | 
«A href=\"?filename=result&action=1ist\"> 学 生成 绩 列表 </A> 

$now_nav=" 学 生成 绩 列 表 "; 

eval ("\$result list = \"".gettemplate('result listone')."\" 

$templatetitle="result"; 

break; 


) 

// 尾 部 文件 的 读 取 

eval ("\$footer = WV"".gettemplate('footer')."N";"); 

// 主 文件 输出 至 浏览 器 

eval ("dooutput (V'".gettemplate (Stemplatetitle) ."\");");// 输 出 至 浏览 器 
?» 


10.6.5 RERE 


在 这 个 系统 里 ， 有 一 个 发 布 文章 的 功能 。 如 果 文 章 多 了 ， 需 要 用 户 对 页 面 进行 设置 ， 
以 方便 阅读 ， 下 面 通过 一 段 代码 (message.php) 进 行 讲解 ， 具 体 如 下 : 
<?php 
// 栏 目 数据 读 取 
if ($typeid) 
t 
$query-"select typename from $table type where 'id'-'$typeid' limit 1"; 
$r-$db-»query first ($query); 
$now typename-$r[typename]; 
H 
else 
t 
$now typename=" 全 部 文章 "; 
H 
if ($action--"") $action-"receive"; 
$tpl-»assign("now typename",$now typename); 
switch ($action) { 
case 'new': 
break; 
case 'receive': 


// 页 码 设置 开始 


人 人 
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$sql = "SELECT count(*) FROM $table message where receive-$user id "; 

$result = $db-»query first ($sql); 

$totalnum=$result[0]; 

$pagenumber = intval ($pagenumber) ; 

if (!isset($pagenumber) or $pagenumber--0) {$pagenumber=1; } 

$curpage- ($pagenumber-1) *$perpage; 

$pagenav-getpagenav ($totalnum, "?filename-message&action-list"); 

// 页 码 设置 结束 

// 记 录 数 据 的 读 取 

$query-"select $table message.*,members.realname from $table message 
LEFT JOIN members ON $table message.send-members.userid 
where receive-$user id 
order by $table message.id DESC limit $curpage,$perpage"; 

$result-$db-»query ($query); 

while($r-$db-»fetch array($result))( 

$sendtime-date ("Y/m/d",$r[sendtime]); 


$content[]-array("id"-»$r[id],"title"-»$r[title], "realname"-»$r[realname 
],"sendtime"-»$sendtime, "content"-»$r[content]); 

5 

$tpl-»assign('pagenav',$pagenav); 

$tpl-»assign('content',S$content); 

break; 

CaSe "Sena: 

// 页 码 设置 开始 

$sql = "SELECT count(*) FROM $table message where send-$user id "; 
$result = $db-»query first ($sql); 

$totalnum=$result[0]; 

$pagenumber = intval ($pagenumber); 

if (!isset($pagenumber) or $pagenumber==0) ($pagenumber-1;] 
$curpage- ($pagenumber-1) *$perpage; 
$pagenav-getpagenav ($totalnum, "?filename-message&action-list"); 


// 页 码 设置 结束 
// 记 录 数 据 的 读 取 


$query-"select $table message.*,members.realname from $table message 
LEFT JOIN members ON $table message.receive-members.userid 
where send-$user id 
order by $table message.id DESC limit $curpage,$perpage"; 
$result-$db-»query ($query) ; 
while ($r=$db->fetch_array ($result) ) { 
$sendtime-date ("Y/m/d",$r[sendtime]); 


$content[]-array("id"-»$r[id],"title"-»$r[title], "realname"-»$r[realname 
],"sendtime"-»$sendtime, "content"-»$r[content]); 

b 

$tpl-»assign('pagenav',$pagenav); 

$tpl-»assign('content',$content); 

break; 


l 
$tpl-»assign('action',$action); 
$tpl-»display('message.html'); 
?» 


今天 ，TuanD 完成 了 基本 管理 功能 模块 的 编码 工作 ， 该 模块 是 用 来 管理 OA 在 线 办 公 
的 最 主要 的 功能 模块 之 一 ， 里 面 有 部 门 管理 、 栏 目 操作 、 用 户 管理 、 学 生成 绩 管理 和 页 面 
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设置 ， 这 些 管理 都 需要 用 户 拥有 一 定 的 权利 ， 如 果 权 利 分 配 不 好 ， 将 会 是 系统 的 漏洞 ， 
而 且 一 个 管理 员 开启 某 一 项 工作 和 关 掉 某 一 项 功能 都 要 尽量 简单 化 ， 这 是 基本 管理 功能 的 
核心 。 


10.7 测 试 


今天 我 们 终于 等 到 了 测试 ， 最 后 的 项 目测 试 工作 由 我 来 完成 。 在 此 我 将 工程 命名 为 


*100a" s 


10.7.1 系统 运行 预览 


现在 开始 运行 测试 ,项 目 运行 后 的 主 界面 效果 如 图 10-13 所 示 , 发 表 文章 界面 如 图 10-14 
所 示 ， 至 于 其 他 的 功能 模块 ， 都 和 这 两 个 图 的 效果 相似 。 
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图 10-13 系统 主 界面 A 10-14 发布 文章 界面 


10.7.2 验收 
ET . 


今天 ， 我 们 的 项 目 正 式 投放 运行 了 ， 客 户 使 用 后 普遍 反映 不 错 。 特 别 是 清新 的 界面 令 
他 们 眼前 一 亮 ， 我 们 也 很 高 兴 。 在 后 期 维护 上 ， 我 们 也 安排 了 分 工 ， 我 留 下 了 工作 室 的 电 
话 作为 全 天 候 服务 热线 。 准 备 开始 为 系统 升级 做 准备 ， 并 考虑 系统 优化 等 方面 的 问题 。 


107.3 总结 


OA 是 面向 团体 的 日 常 运作 和 管理 的 办 公 系 统 , 管理 者 和 员工 使 用 最 多 的 应 用 系统 ， 自 
从 有 了 无 纸 化 办 公 ，OA 系统 就 诞生 了 。 它 的 每 次 进化 都 来 自用 户 使 用 中 的 深刻 感受 。 如 今 
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的 OA 办 公 系 统 界 面 从 平面 到 三 维 ， 流 程 复 杂 到 简单 。 这 些 都 带 给 用 户 新 的 使 用 享受 ， 而 
作为 系统 的 设计 者 ， 则 需要 花费 更 多 的 精力 。 根 据 本 项 目的 亲身 体会 ， 我 总 结 了 以 下 3 点 

1) 现代 化 的 系统 

OA 系统 作为 现代 化 的 办 公 系 统 , 设计 在 搭建 平台 时 要 花 足 工夫 调研 最 基本 和 核心 的 功 
能 。 如 针对 不 同 的 行业 而 通用 的 模板 ， 一 定 要 设计 成 配置 型 。 这 样 ， 不 需要 重复 开发 ， 减 
少 项 目 实施 工期 和 维护 成 本 。 针 对 用 户 量 可 选取 不 同 的 数据 库 ， 为 需要 不 同 的 客户 提供 恰 
当 的 系统 平台 。 

2) 全 能 型 的 系统 

在 竞争 激烈 的 市 场 经 济 中 ， 很 多 公司 为 了 控制 费用 预算 ， 和 希望 把 传统 的 费用 报销 流程 
整合 到 OA 审批 流程 中 ， 也 希望 能 够 有 效 地 管理 资产 ， 如 资产 的 领 用 、 流 转 、 报 修 和 报废 
等 管理 过 程 也 都 希望 整合 到 OA 系统 中 ， 有 的 系统 中 还 含有 视频 会 议 等 。 因此 , 现代 OA R 
统 应 该 具备 多 种 功能 ， 来 满足 不 同行 业 的 使 用 需求 ， 打 造 全 能 型 的 系统 。 

3) 智能 型 的 系统 

当今 科技 发 达 ， 无 论 什么 都 讲究 智能 型 。 同 样 OA 系统 也 应 该 具有 这 种 能 力 ， 对 设计 
者 来 说 ， 平 时 就 应 该 多 留意 用 户 的 不 便 之 处 ， 竭 力 解决 用 户 在 使 用 过 程 中 遇 到 的 繁琐 流程 。 
目前 最 具 代 表 性 的 OA 平台 一 般 都 是 PHP、JAVA 技术 开发 的 ,在 这 种 OA 平台 上 ， 是 在 业 
务 中 做 沟通 ， 而 不 是 在 沟通 中 做 业务 ， 沟 通 、 业 务 、 组 织 和 管理 都 已 经 进入 了 现代 化 。 
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